0

经过大量的谷歌搜索,在这里提问。我希望能够搜索一个字符串以验证一个单词是否在另一个单词之前(在 php 中),但不一定彼此相邻。我很确定这很简单,但很难找到答案!

4

4 回答 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 回答