• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php简简单单搞定中英文混排字符串截取,_php

php 搞代码 3年前 (2018-06-21) 207次浏览 已收录 0个评论

提到中英文混排计数、截取,大家首先想到的是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 要使用的编码
 
 
 
下边给大家实例演示:
 
复制代码
<?php
/**
 * 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()很像,唯一的不同就是可以设定编码。
 
 
 
下边上实例:
 
复制代码
<?php
/**
 * 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啊
复制代码

欢迎大家阅读《php简简单单搞定中英文混排字符串截取,_php》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址