>php教程 >php手册 >php中英文字符串长度截取的例子

php中英文字符串长度截取的例子

WBOY
WBOY원래의
2016-05-25 16:45:091208검색

使用此方法之前,请在php.ini中开启php_mbstring.dll扩展,将extension前面的;分号去掉即可,很多截取中文字符串的方法,大多不能实现按中文个数来截取所要的字符,以下代码可以实现:

<?php
mb_internal_encoding(&#39;UTF-8&#39;);
$str = "中文测试chineseTest";
header(&#39;content-type:text/html; charset=UTF-8&#39;);
echo mb_strlen($str);
echo &#39;<br/>&#39;;
echo mb_substr($str, 1, 6);
?>

输出结果:15 文测试chi

上面只是测试,下面整理例子,代码如下:

<?php
/*mb_string方法截取字符串长度
 * $arr_str 数组或字符串
 * $tlen 截取长度
 * $fleid 要截取的字段(数组形式)
*/
header(&#39;Content-Type: text/html; charset=utf-8&#39;);
function interception($arr_str, $tlen, $fleid = &#39;&#39;) {
    //判断是否是数组
    if (is_array($arr_str)) {
        //将数组下标重新排列
        foreach ($arr_str as $key => $val) {
            for ($k = 0; $k < count($fleid); $k++) {
                $content = $arr_str[$fleid[$k]];
                //判断是否大于指定的长度
                if (mb_strlen($content, &#39;utf-8&#39;) > $tlen) {
                    $arr_str[$fleid[$k]] = mb_substr($content, 0, $tlen, &#39;utf-8&#39;) . &#39;...&#39;;
                }
            }
        }
    }
    //判断是否是字符串
    elseif (is_string($arr_str)) {
        if (mb_strlen($arr_str, &#39;utf-8&#39;) > $tlen) {
            $arr_str = mb_substr($arr_str, 0, $tlen, &#39;utf-8&#39;) . &#39;...&#39;;
        }
    }
    return $arr_str;
}
//使用示例
//数组示例
$array = array(
    &#39;ha&#39; => &#39;哈尔滨市&#39;,
    &#39;bei&#39; => &#39;地球中国北京市&#39;,
);
//字符串示例
$string = &#39;中国的互联网:商业化很牛,公共服务几乎没有谢文&#39;;
$string2 = &#39;abcdefghijkl&#39;;
print_r(interception($array, 2, array(
    &#39;ha&#39;,
    &#39;bei&#39;
)));
echo &#39;<br />&#39; . interception($string, 5);
echo &#39;<br />&#39; . interception($string2, 5);
?>


永久链接:

转载随意!带上文章地址吧。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.