经过大量的谷歌搜索,在这里提问。我希望能够搜索一个字符串以验证一个单词是否在另一个单词之前(在 php 中),但不一定彼此相邻。我很确定这很简单,但很难找到答案!
问问题
90 次
4 回答
1
如果这是唯一的要求,那么也许:
if(($pos = strpos($haystack, $first_word)) !== false && strpos($haystack, $second_word, $pos)) {
// $second_word found after $first_word
}
于 2013-11-14T18:11:47.820 回答
0
也许这
# ^(?:(?!word_after).)*word_before(?:(?!word_after|word_before).)*word_after(?:(?!word_before).)*$
^
(?:
(?! word_after )
.
)*
word_before
(?:
(?! word_after | word_before )
.
)*
word_after
(?:
(?! word_before )
.
)*
$
于 2013-11-14T18:55:57.700 回答
0
你可以试试这个:
if (preg_match('~^(?>[^bg]+|\B[bg]|b(?!adword\b)|g(?!oodword))*+\bgoodword\b~', $str, $match))
echo 'ok';
else
echo 'fail';
您必须取"badword"
("b") 的第一个字母,并且仅在其后不跟随时才允许使用"adword"
^
是字符串开头的锚点
\b
是单词边界,\B
反之亦然。
(?!...)
意思是“不跟随”
将一些文本存储到变量中的示例:$text_before
,$text_after
$flb = preg_quote($text_before[0]);
$fla = preg_quote($text_after[0]);
$subb = substr($text_before, 1);
$suba = substr($text_after, 1);
if( preg_match('~^(?>[^' . $flb . $fla . ']+|\B[' . $flb . $fla ']|'
. $flb . '(?!\Q' . $subb . '\E\b)|'
. $fla . '(?!\Q' . $suba . '\E\b))*+\b'
. $text_after . '\b~', $str, $match) ) {
echo 'ok';
} else {
echo 'fail';
}
于 2013-11-14T18:37:27.400 回答
0
起初我想建议您使用 strpos(),但如果您需要匹配确切的单词,它可能无法正常工作。我正在调查这样的事情:
function AbeforeBinC($a, $b, $string)
{
$aStr = explode(' ', strtolower($string));
foreach($aStr AS $k => $s)
{
if($a == $s){ $a = $k; }
if($b == $s){ $b = $k; }
}
var_dump($a < $b);
}
$str = "We are here to take care of you";
AbeforeBinC('are', 'take', $str);
于 2013-11-14T19:01:45.480 回答