PHP的nb扩展,教你如何轻松处理字符串

提到中英文混排计数、截取,大家首先想到的是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 要使用的编码

/

utf8 编码格式

1个中文占用3个字节

我们希望的是1个中文占用2个字节,

因为从宽度上看2个英文字母占用的位置相当于1个中文

/

// 测试字符串

$str = 'aaaa啊啊aaaa啊啊啊aaa';

echo strlen($str); // 只用strlen输出为25个字节

// 必须指定编码,不然会使用php的内码 mb_internal_encoding()可以查看内码

// 使用mb_strwidth输出字符串的宽度为20使用utf8编码

echo mb_strwidth($str, 'utf8');

// 只有宽度大于10才截取

if(mb_strwidth($str, 'utf8')>10){

// 此处设定从0开始截取,取10个追加...,使用utf8编码

// 注意追加的...也会被计算到长度之内

$str = mb_strimwidth($str, 0, 10, '...', 'utf8');

}

// 最后输出 aaaa啊... 4个a算4个 1个啊算2个 3个点算3个 4+2+3=9

// 是不是很简单啊,有的人说了为什么是9个不是10个吗?

// 因为正好“啊”的后边还是“啊”,中文算2个,9+2=11 超出了设定,所以去掉1个就是9了

echo $str;

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

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

$str 要计算的字符串

$encoding 使用的编码

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

$str 要截取的字符串

$start 从哪里开始截取

$length 截取多长

$encoding 使用的编码

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

如果你还有什么不懂得

欢迎大家在下方留言小编

如果你也想获得更多与同僚

交流的机会,可添加下方微信号

拉你入群,我们一起学习与交流

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180719B1BJ1F00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券