操作步骤:
这个问题看似简单,做起来却有些麻烦,我用一种不太聪明的方式实现:
1、把已有的关键字链接替换成文字
2、把关键字从长至短排列
3、从长至短替换关键字为链接,替换的同时查找有没有包含其他关键字,如果有,把其中子关键字替换成{子关键字的md5值}
4、把{子关键字的md5值}替换回来
函数preg_replace()
参考 http://baike.baidu.com/view/4463003.htm
这个问题看似简单,做起来却有些麻烦,我用一种不太聪明的方式实现:
1、把已有的关键字链接替换成文字
2、把关键字从长至短排列
3、从长至短替换关键字为链接,替换的同时查找有没有包含其他关键字,如果有,把其中子关键字替换成{子关键字的md5值}
4、把{子关键字的md5值}替换回来
<?
header("Content-type: text/html; charset=utf-8");
function _sortDesc($a, $b) {
return (strlen($a[0]) < strlen($b[0])) ? 1 : -1;
}
$linkDefs = array(
'茶叶,111.htm',
'中国茶叶大观,222.htm',
);
$linkMap = array();
foreach($linkDefs as $row) {
$linkMap[] = explode(',', $row);
}
$str = '
这儿是茶叶的链接。<br />
这儿是中国茶叶大观的链接。<br />
这儿是<a href="111.html">茶叶</a>的现有链接。<br />
这儿是<a href="222.html">中国茶叶大观</a>的现有链接。<br />
';
//把原有的链接替换成文字
foreach($linkMap as $row) {
$str = preg_replace('/(<a.*?>\s*)('.$row[0].')(\s*<\/a>)/sui', $row[0], $str);
}
//关键字从长至短排序
usort($linkMap, '_sortDesc');
//var_dump($linkMap);
$tmpKwds = array(); //存放暂时被替换的子关键字
foreach($linkMap as $i=>$row) {
list($kwd, $url) = $row;
for($j=$i+1; $j<count($linkMap); $j++) {
$subKwd = $linkMap[$j][0];
//如果包含其他关键字,暂时替换成其他字符串,如 茶叶 变成
if(strpos($kwd, $subKwd) !== false) {
$tmpKwd = '';
$kwd = str_replace($subKwd, $tmpKwd, $kwd);
$tmpKwds[$tmpKwd] = $subKwd;
}
}
//把文字替换成链接
$str = preg_replace('/('.$row[0].')/sui', '<a href="'.$row[1].'">'.$kwd.'</a>', $str, -1); // 所有的匹配项都会被替换
}
//把代替子关键字的字符串替换回来
foreach($tmpKwds as $tmp=>$kwd) {
$str = str_replace($tmp, $kwd, $str);
}
echo $str;
?>
函数preg_replace()
参考 http://baike.baidu.com/view/4463003.htm