weixin_42734536
2019-11-27 23:10
采纳率: 75%
浏览 1.6k

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文件,所以不是直接删掉其他的,留下数字就行。
跪谢各位大佬!!

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • 毕小宝 2019-11-28 09:22
    已采纳

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

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

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

    点赞 打赏 评论

相关推荐 更多相似问题