使用来自 traceroute 输出的 shell 脚本从文件中提取和查找最小值、最大值和平均值的脚本
Script to extract and find min, max and avg from a file using a shell script from traceroute output
我正在创建一个 shell 脚本来存储 traceroute
命令的输出和用户输入的文件。
我想提取每个数据包和每个路由器的延迟时间,并找出每个数据包的最小、最大和平均时间。
如果这是traceroute
的输出:
1 176.221.87.1 (176.221.87.1) 1.474 ms 1.444 ms 1.390 ms
2 f126.broadband2.quicknet.se (92.43.37.126) 10.047 ms 19.868 ms 23.156 ms
3 10.5.12.1 (10.5.12.1) 24.098 ms 24.340 ms 25.311 ms
我需要找到第一个数据包的所有延迟的最大值,在本例中为 24.098 ms
。同样,最小值为 1.474
,第一个数据包的平均值为 11.873 ms
。我需要为每个数据包执行此操作。
我想要这样的输出:
1 176.221.87.1 (176.221.87.1) 1.474 ms 1.444 ms 1.390 ms
2 f126.broadband2.quicknet.se (92.43.37.126) 10.047 ms 19.868 ms 23.156 ms
3 10.5.12.1 (10.5.12.1) 24.098 ms 24.340 ms 25.311 ms
对于第一个数据包:
Minimum: 1.474 ms
Maximum: 24.098 ms
Average: 11.873 ms
.
.
等等。
我无法想出 awk 语句来执行此操作。也许还有其他方法?
任何意见都会很有帮助。
如果我的理解是正确的,你想要这样的东西
NR == 1 {
n = # set min to first value
u = # keep time unit for later
}
{
s +=
c++
if ( > m) { # update max
m =
}
if ( < n) { # update min
n =
}
}
END {
print "Minimum: " n, u "\nMaximum: " m, u "\nAverage: " s / c, u
}
对于所有三列,您可以轻松扩展它
NR == 1 {
split("4,6,8",ix,",")
for(i in ix) n[ix[i]] = $(ix[i])
u =
}
{
c++
for(i in ix) {
p = ix[i];
s[p] += $(p)
if ($p > m[p]) m[p] = $p
if ($p < n[p]) n[p] = $p
}
}
END {
mins = "Minimum ("u"):"
maxs = "Maximum ("u"):"
avgs = "Average ("u"):"
for(i in ix) {
mins = mins FS n[ix[i]]
maxs = maxs FS m[ix[i]]
avgs = avgs FS s[ix[i]]/c
}
print mins
print maxs
print avgs
}
应该打印
Minimum (ms): 1.474 1.444 1.390
Maximum (ms): 24.098 24.340 25.311
Average (ms): 11.873 15.2173 16.619
我正在创建一个 shell 脚本来存储 traceroute
命令的输出和用户输入的文件。
我想提取每个数据包和每个路由器的延迟时间,并找出每个数据包的最小、最大和平均时间。
如果这是traceroute
的输出:
1 176.221.87.1 (176.221.87.1) 1.474 ms 1.444 ms 1.390 ms
2 f126.broadband2.quicknet.se (92.43.37.126) 10.047 ms 19.868 ms 23.156 ms
3 10.5.12.1 (10.5.12.1) 24.098 ms 24.340 ms 25.311 ms
我需要找到第一个数据包的所有延迟的最大值,在本例中为 24.098 ms
。同样,最小值为 1.474
,第一个数据包的平均值为 11.873 ms
。我需要为每个数据包执行此操作。
我想要这样的输出:
1 176.221.87.1 (176.221.87.1) 1.474 ms 1.444 ms 1.390 ms
2 f126.broadband2.quicknet.se (92.43.37.126) 10.047 ms 19.868 ms 23.156 ms
3 10.5.12.1 (10.5.12.1) 24.098 ms 24.340 ms 25.311 ms
对于第一个数据包:
Minimum: 1.474 ms
Maximum: 24.098 ms
Average: 11.873 ms
.
.
等等。
我无法想出 awk 语句来执行此操作。也许还有其他方法?
任何意见都会很有帮助。
如果我的理解是正确的,你想要这样的东西
NR == 1 {
n = # set min to first value
u = # keep time unit for later
}
{
s +=
c++
if ( > m) { # update max
m =
}
if ( < n) { # update min
n =
}
}
END {
print "Minimum: " n, u "\nMaximum: " m, u "\nAverage: " s / c, u
}
对于所有三列,您可以轻松扩展它
NR == 1 {
split("4,6,8",ix,",")
for(i in ix) n[ix[i]] = $(ix[i])
u =
}
{
c++
for(i in ix) {
p = ix[i];
s[p] += $(p)
if ($p > m[p]) m[p] = $p
if ($p < n[p]) n[p] = $p
}
}
END {
mins = "Minimum ("u"):"
maxs = "Maximum ("u"):"
avgs = "Average ("u"):"
for(i in ix) {
mins = mins FS n[ix[i]]
maxs = maxs FS m[ix[i]]
avgs = avgs FS s[ix[i]]/c
}
print mins
print maxs
print avgs
}
应该打印
Minimum (ms): 1.474 1.444 1.390
Maximum (ms): 24.098 24.340 25.311
Average (ms): 11.873 15.2173 16.619