gpt4 book ai didi

python - 如何使用 python re.findall 过滤掉这种特殊模式?

转载 作者:行者123 更新时间:2023-11-28 21:43:56 25 4
gpt4 key购买 nike

我想在很长的字符串中找出一些特殊的关键字。以下是示例:

long_str = '''
TX[03]
rqn : 0x73
cqn : 0x12
packets : 888
encap : 0
csumNone : 0
csumOk : 0
lroPackets : 0
lroBytes : 0
wqeErr : 0
RX[12]
rqn : 0xa6
cqn : 0x2a
packets : 123
encap : 0
csumNone : 0
csumOk : 0
lroPackets : 0
lroBytes : 0
wqeErr : 0

RX[13]
rqn : 0xa9
cqn : 0x2c
packets : 456
encap : 0
csumNone : 0
csumOk : 0
lroPackets : 0
lroBytes : 0
wqeErr : 0'''
result = re.findall('RX\[\d+\].*packets\s+:\s+(\d+)', a, re.DOTALL)

但是结果['456'],和我预期的['123','456']不一样>.

如何修复我的 re 模式以过滤掉预期值?

提前致谢。

最佳答案

最简单的解决方案是让它变得懒惰:

RX\[\d+\].*?packets\s+:\s+(\d+) 

查看working on regex101.com .
否则,您的 .* 构造会吃掉整个字符串 并在之后回溯(当它找到最后一个数据包 时成功) ,即)。


另一个是:

RX\[\d+\]\n
(?:.+\n){2}
packets\D+(\d+)

参见 this one working here (注意不同的修改器!)。

关于python - 如何使用 python re.findall 过滤掉这种特殊模式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41470707/

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