最近做了个项目,要求查找文章里所有包涵书括号《》的书籍名称,涉及到了全文搜索匹配,百度转了一大圈都是推荐第三方中间件,感觉对于我们这项目有些大材小用 了,于是在php使用文档里找到了解决办法,真是 众里寻它千百度,得来全不费功夫。废话不多说,如下:
现在要获取文章中 《论语》、《孟子》、《大学》、《中庸》名称,如果直接用php中mb_substr,mb_strpos(),将会很麻烦,而且也不能一次全部截取。如果使用php的正则函数,就变得很简单了。
preg_match_all() 函数
int preg_match_all ( string $pattern , string $subject [, array &$matches [, int $flags = PREG_PATTERN_ORDER [, int $offset = 0 ]]] )
$res =Db::name('article')->where($map)->find(); //从数据库查找数据
preg_match_all("/《(.*)》/U", $res['more'], $wordsFound); //匹配《》结果,返回值数组
$wordsFound = array_unique($wordsFound[0]); //去重,把重复结果去掉
var_dump($wordsFound);
打印结果:
再通过php查找替换函数,把书括号去掉,就可以到数据库去匹配想要的结果了
public function cut($begin,$end,$str)
{
$b = mb_strpos($str,$begin) + mb_strlen($begin);
$e = mb_strpos($str,$end) - $b;
return mb_substr($str,$b,$e);
}
最终结果:
哈哈,真开心......