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

PHP中文分詞的簡單實現代碼分享

當然, 本文不是要對中文搜索引擎做研究, 而是分享如果用 php 做一個站內搜索引擎。 本文是這個系統中的一篇。
我使用的分詞工具是中科院計算所的開源版本的 ICTCLAS。 另外還有開源的 Bamboo, 我隨后也會對該工具進行調研。
從 ICTCLAS 出發是個不錯的選擇, 因為其算法傳播比較廣泛, 有公開的學術文檔, 并且編譯簡單, 庫依賴少。 但目前只提供了 C/C++, Java 和 C# 版本的代碼, 并沒有 php 版本的代碼。 怎么辦呢? 也許可以學習它的 C/C++ 源碼和學術文檔中, 然后再開發一個 php 版本出來。 不過, 我要使用進程間通信, 在 php 代碼里調用 C/C++ 版本的可執行文件。
下載源碼解壓后, 在有 C++ 開發庫和編譯環境的機器上直接 make ictclas 即可。 它的 Makefile 腳本有個錯誤, 執行測試的代碼沒有加上'。/', 當然不能像 Windows 下執行成功了。 但也不影響編譯結果。
進行中文分詞的 php 類就在下面了, 用 proc_open() 函數來執行分詞程序, 并通過管道和其交互, 輸入要進行分詞的文本, 讀取分詞結果。
復制代碼 代碼如下:
<?php
class NLP{
private static $cmd_path;
// 不以'/'結尾
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;
}
/**
* 進行分詞, 返回詞語列表.
*/
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 編譯后的可執行文件和詞典在當前目錄):
復制代碼 代碼如下:
<?php
require_once('NLP.php');
var_dump(NLP::tokenize('Hello, World!'));
?>

php技術PHP中文分詞的簡單實現代碼分享,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲色婷婷久久精品AV蜜桃 | FREE另类老女人 | 越南女 黑人 痛苦 大叫 | 欧美高清vivoesosexo10 | 少妇内射视频播放舔大片 | 亚洲成av人影院 | 2023国产精品一卡2卡三卡4卡 | 久久国产主播福利在线 | 国产成人在线视频网站 | 亚洲国产中文字幕在线视频 | 免费的黄直播 | 四虎国产精品永久免费入口 | 国产精品美女久久久久浪潮AV | 久久国产精品自线拍免费 | china野外18:19 | 国产超碰人人爱被IOS解锁 | 内射少妇36P亚洲区 内射少妇36P九色 | 幼儿交1300部一区二区 | 欧美xxxx83d| 亚洲国产精品特色大片观看 | 999精品影视在线观看 | 桃花在线视频观看免费 | 国产人妻777人伦精品HD | 久草热在线| 日本又黄又爽又色又刺激的视频 | 欧美狂野乱码一二三四区 | 激情女人花 | 日本人bbwbbwbbwbbw | 肉色欧美久久久久久久蜜桃 | 美国caopo超碰在线视频 | 亚洲国产五月综合网 | 老师给美女同学开嫩苞 | 久久久久久久久久久福利观看 | 俄罗斯美女啪啪 | 国产99视频精品一区 | 91黄色影院 | 大胆国模一区二区三区伊人 | 欧美不卡一区二区三区 | 久久亚洲人成国产精品 | 蜜柚视频高清在线 | 一个人视频日本在线观看 |