当前位置:首页 > PHP教程 > php应用 > 列表

php轻松实现中英文混排字符串截取

发布:smiling 来源: PHP粉丝网  添加日期:2021-01-15 15:57:12 浏览: 评论:0 

提到中英文混排计数、截取,大家首先想到的是自己写个截取函数,这在之前的文章中我也提到过,今天我给大家分享的是php的mb扩展,教你如何使用原生态的php函数轻松处理字符串。

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

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

$str 要计算的字符串

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

代码如下:

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

$str 要截取的字符串

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

$width 要截取的宽度

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

$encoding 要使用的编码

下边给大家实例演示:

  1. <?php 
  2. /** 
  3.  * utf8 编码格式 
  4.  * 1个中文占用3个字节 
  5.  * 我们希望的是1个中文占用2个字节, 
  6.  * 因为从宽度上看2个英文字母占用的位置相当于1个中文 
  7.  */ 
  8. // 测试字符串 
  9. $str = 'aaaa啊啊aaaa啊啊啊aaa'
  10. echo strlen($str); // 只用strlen输出为25个字节 
  11.  
  12. // 必须指定编码,不然会使用php的内码 mb_internal_encoding()可以查看内码 
  13. // 使用mb_strwidth输出字符串的宽度为20使用utf8编码 
  14. echo mb_strwidth($str'utf8'); 
  15.  
  16. // 只有宽度大于10才截取 
  17. if(mb_strwidth($str'utf8')>10){ 
  18.     // 此处设定从0开始截取,取10个追加...,使用utf8编码 
  19.     // 注意追加的...也会被计算到长度之内 
  20.     $str = mb_strimwidth($str, 0, 10, '...''utf8'); 
  21.  
  22. // 最后输出 aaaa啊... 4个a算4个 1个啊算2个 3个点算3个 4+2+3=9 
  23. // 是不是很简单啊,有的人说了为什么是9个不是10个吗? 
  24. // 因为正好“啊”的后边还是“啊”,中文算2个,9+2=11 超出了设定,所以去掉1个就是9了 
  25. echo $str

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

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

$str 要计算的字符串

$encoding 使用的编码

代码如下:

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

$str 要截取的字符串

$start 从哪里开始截取

$length 截取多长

$encoding 使用的编码

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

下边上实例:

  1. <?php 
  2. /** 
  3.  * utf8 编码格式 
  4.  * 1个中文占用3个字节 
  5.  */ 
  6. $str = 'aa12啊aa'
  7. echo strlen($str); // 直接输出长度为9 
  8. // 输出长度为7,为什么是7呢? 
  9. // 注意这里设定编码以后,不管是中文还是英文每个长度都为1 
  10. // a a 1 2 啊 a a 
  11. // 1+1+1+1+1+1+1 = 7 
  12. // 是不是正好7个字符啊 
  13. echo mb_strlen($str'utf8'); 
  14.  
  15. // 同样mb_substr也是一样的 
  16. // 我现在只想要5个字符 
  17. echo mb_substr($str, 0, 5, 'utf8'); // 输出 aa12啊 

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

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

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

Tags: php字符串截取

分享到: