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

本文介绍了PHP中`mb_strwidth`和`mb_strimwidth`函数的使用,用于计算UTF8编码下字符串的宽度并进行截取。通过示例展示了如何处理中文字符宽度问题,以及与`strlen`和`substr`函数的区别。还提到了`mb_strlen`和`mb_substr`两个类似功能的函数,它们允许指定编码来处理多字节字符。文章适合对PHP字符串处理感兴趣的读者。
摘要由CSDN通过智能技术生成

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

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()很像,唯一的不同就是可以设定编码。

下边上实例:

/**

* utf8 编码格式

* 1个中文占用3个字节

*/

$str = 'aa12啊aa';

echo strlen($str); // 直接输出长度为9

// 输出长度为7,为什么是7呢?

// 注意这里设定编码以后,不管是中文还是英文每个长度都为1

// a a 1 2 啊 a a

// 1+1+1+1+1+1+1 = 7

// 是不是正好7个字符啊

echo mb_strlen($str, 'utf8');

// 同样mb_substr也是一样的

// 我现在只想要5个字符

echo mb_substr($str, 0, 5, 'utf8'); // 输出 aa12啊

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值