-- 更新-- 好的,我已经将范围缩小到要检查的关键字,如果关键字被硬编码到数组中,它们将只与它们之间的空格匹配。如果放入数组中的带空格的关键字是来自数据库的结果,则 preg_match_all 会失败并找到 0 个结果。
所以如果我像这样在 php 中对数组进行硬编码
$myarray = array("This is my Phrase","This is my Second Phrase");
然后对照 texttoscan 检查它,preg_match_all 会找到两个阶段,但是 如果我这样做来创建数组:
$result1 = mysql_result($result,$i,"firstphrase");
$result2 = mysql_result($result,$i,"secondphrase");
$myarray = array($result1,$result2);
下面的 preg_match_all 将失败并且找不到短语,但如果我用单个单词而不是短语填充数组,它将起作用。所以我假设我必须准备包含从数据库返回的空格的字符串,但我不确定该怎么做,或者我需要重新格式化正则表达式模式?
foreach ($myarray as $K) {
$pattern = "/\b($K)\b/";
$count = preg_match_all($pattern, $texttoscan, $matches);
if($count > 0){ echo "matched"; }
}
最佳答案
数据库文本是否可能包含换行符,而硬编码文本却没有?如果是这样,您可能希望使用 m
修饰符来允许多行匹配。这将使正则表达式:
$pattern = "/\b($K)\b/m";
希望对您有所帮助。此外,除非您尝试专门匹配 UTF 单词/字符,否则您应该不会有任何问题。
关于php - preg_match_all 不使用 mysql 数据库结果变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8423264/