仲介交易 HTTP://www.aliyun.com/zixun/aggregation/6858.html">SEO診斷 淘寶客 雲主機 技術大廳
dedecms本身自帶tag(keywords)提取功能,但分詞總是不夠精確。 當然,對於日更新十數篇且對seo精確執行的使用者來說,手工輸入能更好的控制。 但對於主題比較寬泛、內容更新量大的使用者來說,dede split是不大完美的。
discuz線上分詞是一個線上免費的提詞介面。 後有數十萬中文論壇、supsite使用者,對於語境、細胞詞庫的完善有更多的資料。 這個小程式是基於discuz線上分詞批量更新已發內容的keywords(tag),如果資料量大(大於5萬)的或者虛擬主機使用者的話,最好環境搭到本地。 速度會快一點。
使用方法,cms安裝目錄,新建c.php,拷入以下內容,自己對應編碼用notepad設置相應gbk或utf8。 運行 yourwebsite/c.php?id=1
<?php
require_once(dirname(__FILE__).」 /include/common.inc.php」);
$id = isset($id) && is_numeric($id) ? $id : 0;
for ($a=$id; $a<$id+10; $a++){
$row = $dsql->GetOne(」 SELECT arc.title,tp.body FROM `@__archives` arc LEFT JOIN `@__addonarticle` tp ON arc.id=tp.aid where arc.id=’$a’ 「);
if(is_array($row))
{
$title = $row['title'];
$body = $row['body'];
$keywords=zhgetkey($title.$body);
$dsql->ExecuteNoneQuery(」 Update `@__archives` set keywords=’$keywords’ where id=’$a’ 「);
echo $a.’:’.$keywords.’ <br />’;
}
}
if ($a>80000){break;}
echo 「<script>」;
echo 「setTimeout(\」location.replace(‘c.php?id=$a’)\」,0)」;
echo 「</script>」;
function zhgetkey($contents){
$rows = strip_tags($contents);
$arr = array(‘ ‘,’ ‘,」\s」, 「\r\n」, 「\n」, 「\r」, 「\t」, 「>」, 「「」, 「」」,」<br />」);
$qc_rows = str_replace($arr, 」, $rows);
if(strlen($qc_rows)>2400){
$qc_rows = substr($qc_rows, ’0′, ’2400′);
}
$data = @implode(」, file(「HTTP://keyword.discuz.com/related_kw.html?title=$qc_rows&ics=gbk&ocs=gbk」));
preg_match_all(「/<kw>(.*)A\[(.*)\]\](.*)><\/kw>/」,$data, $out, PREG_SET_ORDER);
$key=」";
for($i=0;$i<5;$i++){
$key=$key.$out[$i][2];
if($out[$i][2])$key=$key.」,」;
}
return $key;
}
function cutstr_html($string, $sublen)
{
$string = strip_tags($string);
$string = preg_replace (‘/\n/is’, 」, $string);
$string = preg_replace (‘/ | /is’, 」, $string);
$string = preg_replace (‘/ /is’, 」, $string);
preg_match_all(「/[\x01-\x7f]|[ \xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]| [\xe1-\xef] [\x80-\xbf] [\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]| [\xf1-\xf7] [\x80-\xbf] [\x80-\xbf] [\x80-\xbf]/」, $string, $t_string);
if(count($t_string[0]) – 0 > $sublen) $string = join(」, array_slice($t_string[0], 0, $sublen)).」 ...」;
else $string = join(」, array_slice($t_string[0], 0, $sublen));
return $string;
}
?>