如何使用bash从grep搜索模式中收集最大值和最小值?

我有一个巨大的 log.txt 文件,我需要从中计算最大值和最小值。

 0-00:42:35.598 <tc_testcase>:[DEFAULT]:[PRINT]: tc_testcase.c:8963: VERIFY_CASE: range: X_PER_Y_USER_RANGE_0[1](a, 1)=121, (0)=0, (25000)=25000, (ok)
 0-00:42:35.598 <tc_testcase>:[DEFAULT]:[PRINT]: tc_testcase.c:8963: VERIFY_CASE: range: X_PER_Y_USER_RANGE_0[1](a, 1)=256879, (0)=0, (25000)=25000, (ok)
 0-00:42:35.598 <tc_testcase>:[DEFAULT]:[PRINT]: tc_testcase.c:8963: VERIFY_CASE: range: X_PER_Y_USER_RANGE_0[1](a, 1)=2300, (0)=0, (25000)=25000, (ok)
 0-00:42:35.598 <tc_testcase>:[DEFAULT]:[PRINT]: tc_testcase.c:8963: VERIFY_CASE: range: X_PER_Y_USER_RANGE_0[1](a, 1)=56897132, (0)=0, (25000)=25000, (ok)
 0-00:42:35.598 <tc_testcase>:[DEFAULT]:[PRINT]: tc_testcase.c:8963: VERIFY_CASE: range: X_PER_Y_USER_RANGE_0[1](a, 1)=12579, (0)=0, (25000)=25000, (ok)
 0-00:42:35.598 <tc_testcase>:[DEFAULT]:[PRINT]: tc_testcase.c:8963: VERIFY_CASE: range: X_PER_Y_USER_RANGE_0[1](a, 1)=968746, (0)=0, (25000)=25000, (ok)

因此,作为第一步,我开始使用以下 grep 命令将以下行收集到一个单独的文件中,然后对其进行排序:

 grep -Po '.X_PER_Y_USER_RANGE_0.*[1].*(a, 1).K.*' file.txt > collect.txt

但是我收到的输出完全不同。它看起来像这样:-

=121, (25000)=25000, (ok)
=256879, (25000)=25000, (ok)
=2300, (25000)=25000, (ok)
=56897132, (25000)=25000, (ok)
=12579, (25000)=25000, (ok)
=968746, (25000)=25000, (ok)

预期应该是:-

121
256879
2300
56897132
12579
968746

任何人都可以帮助修改我用来收集值作为预期输出的当前 grep 命令

回答

你很接近,试图在这里修复 OP 的尝试。这可以在 GNU 中完成,grep如下所示。我们可以使用 GNUgrep-P选项在那里启用 PCRE 正则表达式。

grep -oP '.*range: X_PER_Y_USER_RANGE_0[1]([a-zA-Z]+, d+)=Kd+'  Input_file

解释:简单的解释是,首先启用-oPGNU 选项grep以启用 PCRE 正则表达式功能并仅获取匹配的值。然后在 grep 的主程序中,使用正则表达式.*range: X_PER_Y_USER_RANGE_0[1]([a-zA-Z]+, d+)=匹配从开始到直到 () 的所有内容,注意这里转义部分[,],(,)使这些字符成为文字字符。然后使用K选项忘记所有匹配的值到现在为止。提及d+将匹配其后的数字,这是 OP 获取数字的实际要求。


以上是如何使用bash从grep搜索模式中收集最大值和最小值?的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>