gpt4 book ai didi

regex - SED 组输出

转载 作者:太空宇宙 更新时间:2023-11-04 10:58:18 25 4
gpt4 key购买 nike

我正在尝试使用 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com