繁体   English   中英

Python 正则表达式 理解边界“\b”

[英]Python regular expression Understanding Boundary “\b”

输入:

- "example (.com)"

output:

- "example"

我试过的

import re
pattern=re.compile(r'\b\([\W\w]+\)\b')
#pattern=re.compile(r'\([\W\w]+\)')
print(pattern.sub("","example (.com)"))

这不起作用,但如果我删除\b它工作正常 - 为什么?

让自己清楚\b代表什么:

(?:(?=\w)(?<!\w)|(?<=\w)(?!\w))

也就是说,要么是一个单词字符在前面而不是在后面,或者相反。 单词字符 ( \w ) 代表[A-Za-z0-9_]并且不包括( or ) ,因此空格和括号之间没有单词边界。

(不是单词边界,因此\b不会匹配它。相反,您可以使用\B匹配空白

暂无
暂无

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

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