PHP中英混合字符串截取函数代码
作者:
今天在遇到了一个中英字符串截取的问题,在gbk里中文里每个字占两字节,如果全是中文的话,用substr()函数就可以实现了,但中英都有的话就麻烦了,在以前收藏的代码里找到了一个不错的函数,很好的实现了截取的功能
复制代码 代码如下:
function get_word($string, $length, $dot = '..',$charset='gbk') {
if(strlen($string) <= $length) {
return $string;
}
$string = str_replace(array(' ',' ', '&', '"', '<', '>'), array('','','&', '"', '<', '>'), $string);
$strcut = '';
if(strtolower($charset) == 'utf-8') {
$n = $tn = $noc = 0;
while($n < strlen($string)) {
$t = ord($string[$n]);
if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
$tn = 1; $n++; $noc++;
} elseif(194 <= $t && $t <= 223) {
$tn = 2; $n += 2; $noc += 2;
} elseif(224 <= $t && $t < 239) {
$tn = 3; $n += 3; $noc += 2;
} elseif(240 <= $t && $t <= 247) {
$tn = 4; $n += 4; $noc += 2;
} elseif(248 <= $t && $t <= 251) {
$tn = 5; $n += 5; $noc += 2;
} elseif($t == 252 || $t == 253) {
$tn = 6; $n += 6; $noc += 2;
} else {
$n++;
}
if($noc >= $length) {
break;
}
}
if($noc > $length) {
$n -= $tn;
}
$strcut = substr($string, 0, $n);
} else {
for($i = 0; $i < $length; $i++) {
$strcut .= ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];
}
}
return $strcut.$dot;
}
$str = "欢迎 visit 简明 nowamagic";
$str_result = get_word($str, 12);
echo $str_result;
测试运行结果:
欢迎 visit..
您可能感兴趣的文章:
- php中的一个中文字符串截取函数
- 多个PHP中文字符串截取函数
- php中支持多种编码的中文字符串截取函数!
- php字符串截取函数用法分析
- php自定义中文字符串截取函数substr_for_gb2312及substr_for_utf8示例
- PHP中文处理 中文字符串截取(mb_substr)和获取中文字符串字数
- PHP截取汉字乱码问题解决方法mb_substr函数的应用
- php mb_substr()函数截取中文字符串应用示例
- 浅析PHP substr,mb_substr以及mb_strcut的区别和用法
- php截取字符串函数substr,iconv_substr,mb_substr示例以及优劣分析
- php字符串截取函数mb_substr用法实例分析