gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 03:44:20 25 4
gpt4 key购买 nike

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

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com