问题描述
|
在Python正则表达式中,必须^或$
只出现一次?
我试图将两行匹配
^(.*\\|.*)$^.*$
这是行不通的。你如何搭配
几行?
注意:我不是用Python编程,而是在编辑器gedit中使用Python样式的Regex。
谢谢并恭祝安康!
解决方法
正如其他答案所说的那样,您正在寻找ѭ1,但是即使这样,您的正则表达式也无法使用。
$
匹配换行前的位置,^
匹配行的开始,因此正则表达式中间的$^
将永远不匹配。例如:
>>> re.search(\"^(.*)$^.*$\",multiline_string,re.M) # won\'t match
>>> re.search(\"^(.*)$\\n^.*$\",re.M) # will match
<_sre.SRE_Match object at 0xb7f3e5e0>
您需要一些东西来匹配$
和^
之间的行尾字符。
,看一下re.MULTILINE
。
我引用:
指定后,图案字符
the9ѭ比赛的开始
字符串和每个开头
行(紧随每个
新队);和图案字符
字符串末尾有“ 10”个匹配项
在每一行的末尾
(紧接在每个换行符之前)。
默认情况下,\'^\'
仅在
字符串的开头,仅\'$\'
在字符串的末尾和
紧接换行符之前(如果
任意)在字符串的末尾。
,您必须使用re.MULTILINE(如果您更改正则表达式并根据您实际想要匹配的内容/甚至使用re.DOTALL)
重新多行
指定后,图案字符
\'^ \'开头匹配
字符串的开头
每行(紧随每行
新队);和图案字符
\'$ \'匹配字符串的末尾
在每一行的末尾
(紧接在每个换行符之前)。
默认情况下,\'^ \'仅匹配
字符串的开头,仅\'$ \'
在字符串的末尾和
紧接换行符之前(如果
任意)在字符串的末尾。
http://docs.python.org/library/re.html
顺便说一句,你在做什么-^(.*\\|.*)$^.*$
-这不是一个很好的正则表达式! (忽略了事实,即问题所在是$
和^
的倍数。)
,添加到其他答案。您可以将re.MULTILINE修饰符直接放到正则表达式中以摆脱困境:
(?m)^(.*\\|.*)$\\n^.*$
,我会参考python regex手册http://docs.python.org/library/re.html#re.MULTILINE
,用(?m)前缀正则表达式应该可以满足您的需要(告诉正则表达式引擎它将接收多行文本,并且^ / $匹配行的开头/结尾而不是整个文本)。
编辑:多看了一下正则表达式后,我认为您还需要放(?s),这意味着您希望点匹配换行符。例如:
(?m)(?s)^hello.*?world$
在这样的情况下为我正确匹配了“ helloworld”:
dssdf
hello
world
sdfasdf