gpt4 book ai didi

python - 运行正则表达式时出现虚假转义错误

转载 作者:太空狗 更新时间:2023-10-30 02:45:15 25 4
gpt4 key购买 nike

昨天,我在正则表达式匹配方面得到了帮助,它作为独立版本运行良好。但是当输入这段代码时,我得到了“伪造的转义错误”。代码和回溯如下。你能指出我做错了什么吗?

#!/usr/bin/env python
import re

sf = open("a.txt","r")
out = open("b.txt","w")
regex = re.compile(r'Merging\s+\d+[^=]*=\s*\'\w+@\w+\x\w+\'\\"')


for line in sf:
m = regex.findall(line)
for i in m:
print >> out,line,

回溯是:

Traceback (most recent call last): File "match.py", line 6, in <module>
regex = re.compile(r'Merging\s+\d+[^=]*=\s*\'\w+@\w+\x\w+\'\\"')
File "/usr/lib/python2.7/re.py", line 190, in compile
return _compile(pattern, flags)
File "/usr/lib/python2.7/re.py", line 242, in _compile
raise error, v # invalid expression
sre_constants.error: bogus escape: '\\x'

最佳答案

\x 不是有效的特殊序列。如果你想匹配文字 \x,你需要使用 \\x 转义反斜杠,或者如果你需要其他东西,使用 valid one ,就像您对 \w 所做的那样。

这将编译:

re.compile(r'Merging\s+\d+[^=]*=\s*\'\w+@\w+\\x\w+\'\\"')

关于python - 运行正则表达式时出现虚假转义错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25408422/

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