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