php - preg_match_all 不使用 mysql 数据库结果变量?

标签 php mysql preg-match-all

-- 更新-- 好的,我已经将范围缩小到要检查的关键字,如果关键字被硬编码到数组中,它们将只与它们之间的空格匹配。如果放入数组中的带空格的关键字是来自数据库的结果,则 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/

相关文章:

mysql - 如何在MySQL中正确使用IN?

php - preg_match_all 只匹配一个

php - Google App Engine PHP 文件上传

mysql - SQL,选择几年之前,但不选择之后

php - CSS 动画在 Firefox 和 IE 上不起作用

PHP循环遍历数组以从数据库中获取每个键的值(第三范式)

javascript - 使用php从字符串中删除带有类名的div

php - 为什么 preg_match_all 返回两个匹配项?

php - 将大型数组转换为无循环的关联数组

PHP 从前 24 小时 sql 数据库中选择数据