源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
查看: 231|回复: 39

[PHP编程] php 一元分词算法

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2009-11-30 21:09:39 | 显示全部楼层 |阅读模式
php 一元分词算法

复制代码 代码如下:

/**
* 一元分词算法
* UTF8编码下一个字符如果首字符ASCII码不大于192则只占1个字节
* 如果首字符ASCII码大于192小于224则占用2个字节,否则占用3个字节
* 一元分词需要在mysql的my.ini文件中增加 ft_min_word_len=1
* 可以使用mysql查询语句 show variables like '%ft%' 查看mysql全文搜索相关设置
*
* @access global
* @param string $str
* @param boolean $unique 是否去除重复值
* @param boolean $merge 是否合并附加值
* @return array
*/
function seg_word($str,$unique=false,$merge=true)
{
$str = trim(strip_tags($str));
$strlen = strlen($str);
if($strlen == 0) return array();
$spc = ' ';
//按需增加需要过滤的字符
$search = array(',', '/', '\\', '.', ';', ':', '\'', '!', '~','"', '`', '^', '(', ')', '?', '-', "\t", "\n", '\'', '<', '>', "\r", "\r\n", '\$', '&', '%', '#', '@', '+', '=', '{', '}', '[', ']', ')', '(', '.', '。', ',', '!', ';', '“', '”', '‘', ''', '[', ']', '、', '—', ' ', '《', '》', '-', '…', '【', '】',':');
$numpairs = array('1'=>'一','2'=>'二','3'=>'三','4'=>'四','5'=>'五','6'=>'六','7'=>'七','8'=>'八','9'=>'九','0'=>'零');
$str = alab_num($str);
$str = str_replace($search,' ',$str);
$ord = $i = $k = 0;
$prechar = 0;// 0-空白 1-英文和符号 2-中文
$result = array();
$annex = array();

while($ord = ord($str[$i]))
{
//1字节字符
if ($ord <= 0xC0 )
{
//去除空字符串
if($ord < 33) {
$prechar=0;
$i++;
$k++;
continue;
}
//附加中文大写数字转换
if(isset($numpairs[$str[$i]])) {
$annex[]=$numpairs[$str[$i]];
}
//如果前面是中文
if( $prechar == 2 ){
$result[++$k] = $str[$i];
}
else {
$result[$k] .= $str[$i];
}
$prechar = 1;
$i++;
}
else //2-3字节字符(中文)
{
if($ord < 0xE0)
$step = 2;
else
$step = 3;
$c = substr($str,$i,$step);
if(false !== $key = array_search($c,$numpairs)){
$annex[] = $key;
}
if ($prechar != 0) {
$result[++$k] = $c;
}
else {
$result[$k] .= $c;
}

$prechar = 2;
$i+=$step;
}
}
$result = $merge ? array_merge($result,$annex) : $result ;
return $unique ? array_unique($result) : $result ;
}

回复

使用道具 举报

0

主题

2万

回帖

186

积分

注册会员

Rank: 2

积分
186
发表于 2022-9-9 02:28:06 | 显示全部楼层
啦啦啦啦啦啦哈哈哈
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-9-13 04:24:14 | 显示全部楼层
66666666666
回复 支持 反对

使用道具 举报

匿名  发表于 2022-9-13 05:58:02

slots free

free slot machines
<a href="https://casino-online-slots-real.com/">slot machine</a>
play slots
<a href="https://free-slots-casino.us/">casino real money</a>
free casino games
<a href="https://slotsonfreegames.com/">free slot machines</a>
回复 支持 反对

使用道具

匿名  发表于 2022-9-13 05:58:39

casino games

casino real money
<a href="https://casino-online-slots-real.com/">casino games slots free</a>
slot games
<a href="https://free-slots-casino.us/">online casino</a>
free online slots
<a href="https://slotsonfreegames.com/">free slots online</a>
回复 支持 反对

使用道具

匿名  发表于 2022-9-13 05:59:13

slot games

УОН 37.139.53.x ·±нУЪ 2022-9-13 05:58
free slot machines
slot machine
play slots

casino slots
<a href="https://casino-online-slots-real.com/">casino games</a>
online casino real money
<a href="https://free-slots-casino.us/">slots games</a>
casino real money
<a href="https://slotsonfreegames.com/">free slots</a>
回复 支持 反对

使用道具

匿名  发表于 2022-9-13 05:59:52

free online slot machines

УОН 37.139.53.x ·±нУЪ 2022-9-13 05:58
free slot machines
slot machine
play slots

free casino slots
<a href="https://casino-online-slots-real.com/">slots games</a>
slots
<a href="https://free-slots-casino.us/">online casino</a>
free slot games
<a href="https://slotsonfreegames.com/">free casino games</a>
回复 支持 反对

使用道具

匿名  发表于 2022-9-13 06:00:30

slots

УОН 37.139.53.x ·±нУЪ 2022-9-13 05:59
free casino slots
slots games
slots

play slots
<a href="https://casino-online-slots-real.com/">free slot machines</a>
slot
<a href="https://free-slots-casino.us/">online casino</a>
slots free online
<a href="https://slotsonfreegames.com/">free slots online</a>
回复 支持 反对

使用道具

匿名  发表于 2022-9-13 06:01:07

free slots no registration or downloading

ШёУГ§5 ·±нУЪ 2022-9-9 02:28
АААААА№ю№ю№ю

free slots
<a href="https://casino-online-slots-real.com/">slot machine</a>
casino games
<a href="https://free-slots-casino.us/">casino game</a>
casino real money
<a href="https://slotsonfreegames.com/">online casino</a>
回复 支持 反对

使用道具

匿名  发表于 2022-9-13 06:01:42

free online slot machines

free slots no download
<a href="https://casino-online-slots-real.com/">slots games</a>
slot machine
<a href="https://free-slots-casino.us/">slots casino</a>
online casino real money
<a href="https://slotsonfreegames.com/">free slots</a>
回复 支持 反对

使用道具

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2025-2-4 02:51 , Processed in 0.069256 second(s), 26 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表