天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

PHP中文分詞的簡單實(shí)現(xiàn)代碼分享

當(dāng)然, 本文不是要對中文搜索引擎做研究, 而是分享如果用 php 做一個(gè)站內(nèi)搜索引擎。 本文是這個(gè)系統(tǒng)中的一篇。
我使用的分詞工具是中科院計(jì)算所的開源版本的 ICTCLAS。 另外還有開源的 Bamboo, 我隨后也會(huì)對該工具進(jìn)行調(diào)研。
從 ICTCLAS 出發(fā)是個(gè)不錯(cuò)的選擇, 因?yàn)槠渌惴▊鞑ケ容^廣泛, 有公開的學(xué)術(shù)文檔, 并且編譯簡單, 庫依賴少。 但目前只提供了 C/C++, Java 和 C# 版本的代碼, 并沒有 php 版本的代碼。 怎么辦呢? 也許可以學(xué)習(xí)它的 C/C++ 源碼和學(xué)術(shù)文檔中, 然后再開發(fā)一個(gè) php 版本出來。 不過, 我要使用進(jìn)程間通信, 在 php 代碼里調(diào)用 C/C++ 版本的可執(zhí)行文件。
下載源碼解壓后, 在有 C++ 開發(fā)庫和編譯環(huán)境的機(jī)器上直接 make ictclas 即可。 它的 Makefile 腳本有個(gè)錯(cuò)誤, 執(zhí)行測試的代碼沒有加上'。/', 當(dāng)然不能像 Windows 下執(zhí)行成功了。 但也不影響編譯結(jié)果。
進(jìn)行中文分詞的 php 類就在下面了, 用 proc_open() 函數(shù)來執(zhí)行分詞程序, 并通過管道和其交互, 輸入要進(jìn)行分詞的文本, 讀取分詞結(jié)果。
復(fù)制代碼 代碼如下:
<?php
class NLP{
private static $cmd_path;
// 不以'/'結(jié)尾
static function set_cmd_path($path){
self::$cmd_path = $path;
}
private function cmd($str){
$descriptorspec = array(
0 => array("pipe", "r"),
1 => array("pipe", "w"),
);
$cmd = self::$cmd_path . "/ictclas";
$process = proc_open($cmd, $descriptorspec, $pipes);
if (is_resource($process)) {
$str = iconv('utf-8', 'gbk', $str);
fwrite($pipes[0], $str);
$output = stream_get_contents($pipes[1]);
fclose($pipes[0]);
fclose($pipes[1]);
$return_value = proc_close($process);
}
/*
$cmd = "printf '$input' | " . self::$cmd_path . "/ictclas";
exec($cmd, $output, $ret);
$output = join("/n", $output);
*/
$output = trim($output);
$output = iconv('gbk', 'utf-8', $output);
return $output;
}
/**
* 進(jìn)行分詞, 返回詞語列表.
*/
function tokenize($str){
$tokens = array();
$output = self::cmd($input);
if($output){
$ps = preg_split('//s+/', $output);
foreach($ps as $p){
list($seg, $tag) = explode('/', $p);
$item = array(
'seg' => $seg,
'tag' => $tag,
);
$tokens[] = $item;
}
}
return $tokens;
}
}
NLP::set_cmd_path(dirname(__FILE__));
?>

使用起來很簡單(確保 ICTCLAS 編譯后的可執(zhí)行文件和詞典在當(dāng)前目錄):
復(fù)制代碼 代碼如下:
<?php
require_once('NLP.php');
var_dump(NLP::tokenize('Hello, World!'));
?>

php技術(shù)PHP中文分詞的簡單實(shí)現(xiàn)代碼分享,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产国产乱老熟女视频网站97 | 亚洲地址一地址二地址三 | 白丝美女被狂躁免费漫画 | 小柔的性放荡羞辱日记 | 亚洲人成网站在线播放 | 久久99精国产一区二区三区四区 | 中文字幕久久熟女人妻AV免费 | 久久亚洲免费视频 | 国产成人精品区在线观看 | XXOO麻豆国产在线九九爱 | 蜜桃传媒在线观看 | 精品一区二区三区在线成人 | 理论片午午伦夜理片久久 | 久热在线这里只有精品7 | 丰满五十六十老熟女HD60 | 日韩欧美三区 | 老阿姨才是最有味的一区二区 | 日韩专区亚洲国产精品 | 棉签和冰块怎么弄出牛奶视频 | 欧美乱妇狂野欧美在线视频 | 肉多的小说腐小说 | 欧美xxxxx九色视频免费观看 | 久久青草免费线观最新 | 成人亚洲精品 | 久久精品九九亚洲精品天堂 | 小黄文纯肉污到你湿 | 亚洲三级在线看 | 成人精品视频在线 | 久久www免费人成_看片高清 | 亚洲第一色网 | 国产精品人成视频免费999 | 爆操大胸美女 | 久久精品视频15人人爱在线直播 | 亚洲 欧美 制服 校园 动漫 | 影音先锋色av男人资源网 | 亲胸揉胸膜下刺激视频网站APP | 少妇的肉体AA片免费观看 | 大胸美女被c | 久久本道久久综合伊人 | ca88亚洲城娱乐 | 麻豆狠色伊人亚洲综合网站 |