Linux 提取文件中指定列数的字符串

图片说明

我的log文件内容如上,对log文件做如下操作:

[tyy@root] grep -i "run_" real.log | awk '{print $5, $6}'

输出内容为

[tyy@root] 
file number
file number
file number

56740在log文件里显示的是从36列到40列(每个字符和空格都算一列)我以为这样可以输出36列到40列,也就是我想要的5开头的数字,

[tyy@root] grep -i "run_" real.log | awk '{print $36, $40}'

但其实awk print $ 列是按一个字符串算的,一个字符串算作一列,就像上面的输出一样。所以$36,$40 输出的就是一些空格。

现在我想提取文件里的数字,5开头的5位,不要00,请问该如何做?PS:有很多这种log文件,所以不是直接删掉其他的,留下数字就行。
跪谢各位大佬!!

先取第 7 列,得到数值所在列,再用下划线分割,取第二列,最后在用00分割

cat test.log | awk '{print $7}' |awk -F _ '{print $2}'| awk -F "00" '{print $2}'

这种写法前提是 Number 的生成格式是一样的,都是 00 开头的。结果:
图片说明