本文介绍了正则表达式匹配上一次出现的任一关键字的所有内容的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在尝试匹配从上次出现的任一关键字(foo或bar)到字符串末尾的所有内容。
示例(A):
// I want to match ' foo do you?';
$source = 'This is foo and this is bar i like foo do you?';
$pattern = '/pattern/';
preg_match($pattern, $source, $matches);
我尝试了以下操作:
$pattern = '/( (foo|bar) .*)$/';
认为它将匹配foo
的最后一个匹配项和以下所有文本,但它却匹配第一个匹配项。
print_r($matches);
/*
Array
(
[0] => foo and this is bar i like foo do you?
[1] => foo and this is bar i like foo do you?
[2] => foo
)
*/
注意我关心的是如何执行此操作的理论和推理,因此请添加一些解释或指向相关解释的链接。
推荐答案
.+((foo|bar).+)$
.+预先匹配多个字符。
((foo|bar)匹配并捕获您的关键字。
.+)匹配并捕获许多字符。
$匹配字符串/行的结尾。
使用您的示例:
This is foo and this is bar i like foo do you?
^---------^
这篇关于正则表达式匹配上一次出现的任一关键字的所有内容的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!