一个正则表达式引起的杂谈

前端之家收集整理的这篇文章主要介绍了一个正则表达式引起的杂谈前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

re.compile(r'(?s)\s*usage: (.*?)(\n[ \t]*\n|$)')

一开始咋也不能明白啥意思

探索第一步:

(.*?)非贪婪模式的正则匹配


http://www.jb51.cc/article/p-cpcviwtg-ry.html

博客介绍的非常好


(?s)

正则 (?i,m,s,x,g) 正则i,g 这些是模式修正符 -- 解说正则表达式模式中使用的修正符 i 如果设定此修正符,模式中的字符将同时匹配大小写字母。 m 当设定了此修正符,“行起始”和“行结束”除了匹配整个字符串开头和结束外,还分别匹配其中的换行符的之后和之前。 s 如果设定了此修正符,模式中的圆点元字符(.)匹配所有的字符,包括换行符。没有此设定的话,则不包括换行符。 x 如果设定了此修正符,模式中的空白字符除了被转义的或在字符类中的以外完全被忽略,在未转义的字符类之外的 # 以及下一个换行符之间的所有字符,包括两头,也都被忽略。 e 如果设定了此修正符,preg_replace() 在替换字符串中对逆向引用作正常的替换

原文链接:https://www.f2er.com/regex/361987.html

猜你在找的正则表达式相关文章