这个问题在这里已经有了答案:
My regex is matching too much. How do I make it stop? [duplicate]
(5 个回答)
2年前关闭。
我有以下几行:
"14:48 say;0ed673079715c343281355c2a1fde843;2;laka;hello ;)"
我通过使用一个简单的正则表达式来解析它:
if($line =~ /(\d+:\d+)\ssay;(.*);(.*);(.*);(.*)/) {
my($ts, $hash, $pid, $handle, $quote) = ($1, $2, $3, $4, $5);
}
但是;最后把事情搞砸了,我不知道为什么。贪婪的运算符不应该处理“一切”吗?
最佳答案
贪婪操作符试图尽可能多地获取内容并仍然匹配字符串。发生的事情是第一个(在“say”之后)获取“0ed673079715c343281355c2a1fde843;2”,第二个获取“laka”,第三个获取“hello”,第四个匹配括号。
您需要做的是使除最后一个之外的所有内容都非贪婪,因此它们尽可能少地抓取并仍然匹配字符串:
(\d+:\d+)\ssay;(.*?);(.*?);(.*?);(.*)
关于regex - 如何修复我的正则表达式以使其与贪婪的量词不匹配?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/255815/