Rumah  >  Artikel  >  pembangunan bahagian belakang  >  php简简单单搞定中英文混排字符串截取,只需2行代码!_PHP教程

php简简单单搞定中英文混排字符串截取,只需2行代码!_PHP教程

WBOY
WBOYasal
2016-07-13 10:29:19755semak imbas

提到中英文混排计数、截取,大家首先想到的是ascii、16进制、正则匹配、循环计数。

今天我给大家分享的是php的mb扩展,教你如何轻松处理字符串。


 

先给大家介绍用到的函数:

mb_strwidth($str, $encoding) 返回字符串的宽度

$str 要计算的字符串

$encoding 要使用的编码,如 utf8、gbk

mb_strimwidth($str, $start, $width, $tail, $encoding) 按宽度截取字符串

$str 要截取的字符串

$start 从哪个位置开始截取,默认是0

$width 要截取的宽度

$tail 追加到截取字符串后边的字符串,常用的是 ...

$encoding 要使用的编码


 

下边给大家实例演示:

<?<span>php
</span><span>/*</span><span>*
 * utf8 编码格式
 * 1个中文占用3个字节
 * 我们希望的是1个中文占用2个字节,
 * 因为从宽度上看2个英文字母占用的位置相当于1个中文
 </span><span>*/</span>

<span>//</span><span> 测试字符串</span>
<span>$str</span> = 'aaaa啊啊aaaa啊啊啊aaa'<span>;
</span><span>echo</span> <span>strlen</span>(<span>$str</span>); <span>//</span><span> 只用strlen输出为25个字节

// 必须指定编码,不然会使用php的内码 mb_internal_encoding()可以查看内码
// 使用mb_strwidth输出字符串的宽度为20使用utf8编码</span>
<span>echo</span> mb_strwidth(<span>$str</span>, 'utf8'<span>); 

</span><span>//</span><span> 只有宽度大于10才截取</span>
<span>if</span>(mb_strwidth(<span>$str</span>, 'utf8')>10<span>){
    </span><span>//</span><span> 此处设定从0开始截取,取10个追加...,使用utf8编码
    // 注意追加的...也会被计算到长度之内</span>
    <span>$str</span> = mb_strimwidth(<span>$str</span>, 0, 10, '...', 'utf8'<span>);
}

</span><span>//</span><span> 最后输出 aaaa啊... 4个a算4个 1个啊算2个 3个点算3个 4+2+3=9
// 是不是很简单啊,有的人说了为什么是9个不是10个吗?
// 因为正好&ldquo;啊&rdquo;的后边还是&ldquo;啊&rdquo;,中文算2个,9+2=11 超出了设定,所以去掉1个就是9了</span>
<span>echo</span> <span>$str</span>;

 


 

下边再给大家介绍一些其它函数吧:

mb_strlen($str, $encoding) 返回字符串的长度

$str 要计算的字符串

$encoding 使用的编码

mb_substr($str, $start, $length, $encoding) 截取字符串

$str 要截取的字符串

$start 从哪里开始截取

$length 截取多长

$encoding 使用的编码

其实这2个函数和strlen()、substr()很像,唯一的不同就是可以设定编码。


 

下边上实例:

<?<span>php
</span><span>/*</span><span>*
 * utf8 编码格式
 * 1个中文占用3个字节
 </span><span>*/</span>
<span>$str</span> = 'aa12啊aa'<span>;
</span><span>echo</span> <span>strlen</span>(<span>$str</span>); <span>//</span><span> 直接输出长度为9

// 输出长度为7,为什么是7呢?
// 注意这里设定编码以后,不管是中文还是英文每个长度都为1
// a a 1 2 啊 a a 
// 1+1+1+1+1+1+1 = 7
// 是不是正好7个字符啊</span>
<span>echo</span> mb_strlen(<span>$str</span>, 'utf8'<span>);

</span><span>//</span><span> 同样mb_substr也是一样的
// 我现在只想要5个字符</span>
<span>echo</span> mb_substr(<span>$str</span>, 0, 5, 'utf8'); <span>//</span><span> 输出 aa12啊</span>

 


 

其实mb扩展里边很有很多好用的函数,这里就不给大家一一列举。

有兴趣的朋友可以查看官方手册

http://www.php.net/manual/zh/ref.mbstring.php

好了,今天就先介绍到这里了。

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/777158.htmlTechArticle提到中英文混排计数、截取,大家首先想到的是ascii、16进制、正则匹配、循环计数。 今天我给大家分享的是php的mb扩展,教你如何轻松处理...
Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn