regex - SED 组输出

标签 regex linux bash sed tr

我正在尝试使用 SED 命令在文件中查找模式。 不知何故,我的正则表达式不起作用,尽管我希望它能起作用。

详细信息: 文本文件 aaa.log 包含以下数据:

007ba20: fa2e1438 fa3e1438 d1af9a57 d0000000  8...8.>.W.......
007ba30: d0006813 d3af9a17 d2000009 d200001d  .h..............
007ba40: d1af9a52 d0004a43 d000505f d3af9b12  R...CJ.._P......
007ba50: d2000009 d20000d3 04100012 04404350  ............PC@.
007ba60: 0440004a 04100001 059a4393 059a0002  J.@......C......
007ba70: 04100005 04100000 04100000 059a4153  ............SA..
007ba80: 059a4154 059a4162 059c40fc 04100012  TA..bA...@......
007ba90: 04404350 0440004a 04100001 059c4392  PC@.J.@......C..
007baa0: 059c40f5 0440a350 0440004a 04404350  .@..P.@.J.@.PC@.
007bab0: 0440004a 04400068 04400000 04100000  J.@.h.@...@.....
007bac0: 04100000 059c410f 059e4193 03a00001  .....A...A......
007bad0: 03a04255 03a04292 03a04294 02400000  UB...B...B....@.
007bae0: 02408009 02100000 03a04215 028005b1  ..@......B......

我的目的是跟踪以 d1 和 d0 开头的所有 8 个字符模式,后跟 6 个任意字符,然后是空格

据此,我形成了如下一行:

p=".*(d1.{6}|d0.{6})[[:space:]].*"; cat aaa.log | tr '\r\n' ' ' | sed -rn "s/$p$p$p$p$p$p/\1 \2 \3 \4 \5 \6\n/p"

正如您在 aaa.log 中看到的那样,存在六组 $p。确实找到了输出:

d1af9a57 d0000000 d0006813 d1af9a52 d0004a43 d000505f

然而,由于 aaa.log 文件中没有第 7 个 $p 模式,当我使用以下语法时:

p=".*(d1.{6}|d0.{6})[[:space:]].*"; cat aaa.log | tr '\r\n' ' ' | sed -rn "s/$p$p$p$p$p$p$p/\1 \2 \3 \4 \5 \6 \7\n/p"

失败并且不打印任何输出。

我假设由于模式 7 不存在而未打印输出。

知道如何在未找到某些模式的情况下将匹配的组打印为输出吗?

最佳答案

grep -o "d1[^ ]\{6\}\|d0[^ ]\{6\}" 怎么样?

关于regex - SED 组输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27960160/

相关文章:

regex - 从 Postgresql 中的列中仅获取第一个字母单词

c - NMEA 正则表达式匹配 : Invalid preceding regular expression error

c - 为什么调用函数时要使用(void)?

linux - 处理二进制文件时获得与 cat 类似的输出

linux - 没有错误时 Bash 错误重定向创建文件

c++ - 正则表达式在 QRegEx 中给出了错误的匹配

javascript - 如何在 jQuery 中为关键字解析文本?

c++ - 如何与SDL库链接?

linux - 无法使 cronjob 获取服务状态

regex - 如何在找到与 sed 的匹配项后仅追加一行?