繁体   English   中英

Python匹配替换,我做错了什么?

[英]Python match and replace, what I do wrong?

我有用于匹配某些数据的reg exp( 在这里 ),现在我尝试将所有匹配的数据替换为single : characetr

test_str = u"THERE IS MY DATA"
p = re.compile(ur'[a-z]+([\n].*?<\/div>[\n ]+<div class="large-3 small-3 columns">[\n ]+)[a-z]+', re.M|re.I|re.SE) 
print re.sub(p, r':/1',test_str) 

我以其他几种方式尝试它,但它不能替换任何东西,或者不仅替换匹配的而且替换整个模式

1)这是反斜杠问题。
使用: print re.sub(p, r':\\1',test_str)print re.sub(p, r':/1',test_str)
2)您要用:\\1替换所有模式,这意味着要用:替换所有文本,然后是正则表达式中的第一组。
要仅替换文本中的第一个组,应在第一个和之后添加两个组。 我希望这可以解决问题:

test_str = u"THERE IS MY DATA" 
p = re.compile(ur'([a-z]+)([\n].*?<\/div>[\n ]+<div class="large-3 small-3 columns">[\n ]+)([a-z]+)', re.M|re.I|re.SE) 
print re.sub(p, r'\1:\2\3',test_str)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM