查找包含关键字和提取编号的所有行

问题描述 投票:0回答:1

我想找到从单词开头的行:“ERRORS”并从该行中提取数字。

部分文件:

...
[ERROR] No keywords and test cases defined in file
File path: libraries_instances.robot

TEST SUITES SUMMARY:
ERRORS:        148
WARNINGS:      89
CS VIOLATIONS: 201

我的解决方案是:

grep ERRORS .validation.log | grep -o -E '[0-9]+'

有可能使它更好,只使用一个grep?

最后,我想在我的bash脚本中将该值赋给变量。

linux bash grep text-processing
1个回答
2
投票

由于linux标签存在问题,假设GNU grep-P选项可用

$ grep -oP 'ERRORS.*\h\K\d+' .validation.log
148
  • ERRORS.*\h\K这里的\K选项有助于标记正则表达式的起点..匹配到此点的字符串不会是输出的一部分
  • 还要注意man grep警告使用-P作为实验,但到目前为止我还没有遇到任何问题..(请参阅https://debbugs.gnu.org/cgi/pkgreport.cgi?package=grep了解已知的GNU grep问题)

使用awk的替代解决方案

$ awk '/ERRORS:/ && NF==2{print $NF}' .validation.log
148
  • /ERRORS:/ && NF==2匹配包含ERRORS:的行并且只有两个字段(默认情况下,一个或多个连续的空格是字段分隔符)
  • print $NF打印最后一个字段
© www.soinside.com 2019 - 2024. All rights reserved.