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

提到中英文混排计数、截取,大家首先想到的是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啊
复制代码

时间: 2024-10-30 15:02:18

php简简单单搞定中英文混排字符串截取,只需2行代码!的相关文章

实现中英文混排字符串截取的php代码

提到中英文混排计数.截取,大家首先想到的是ascii.16进制.正则匹配.循环计数. 今天我给大家分享的是php的mb扩展,教你如何轻松处理字符串. 先给大家介绍用到的函数: mb_strwidth($str, $encoding) 返回字符串的宽度 $str 要计算的字符串 $encoding 要使用的编码,如 utf8.gbk mb_strimwidth($str, $start, $width, $tail, $encoding) 按宽度截取字符串 $str 要截取的字符串 $start

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

先给大家介绍用到的函数: 复制代码 代码如下: mb_strwidth($str, $encoding) 返回字符串的宽度$str 要计算的字符串$encoding 要使用的编码,如 utf8.gbk 复制代码 代码如下: mb_strimwidth($str, $start, $width, $tail, $encoding) 按宽度截取字符串$str 要截取的字符串$start 从哪个位置开始截取,默认是0$width 要截取的宽度$tail 追加到截取字符串后边的字符串,常用的是 ...$

php mb_strwidth函数实现中英文混排字符串截取

mb_strwidth($str, $encoding) 返回字符串的宽度 $str 要计算的字符串 $encoding 要使用的编码,如 utf8.gbk mb_strimwidth($str, $start, $width, $tail, $encoding) 按宽度截取字符串 $str 要截取的字符串 $start 从哪个位置开始截取,默认是0 $width 要截取的宽度 $tail 追加到截取字符串后边的字符串,常用的是 ... $encoding 要使用的编码  代码如下 复制代码 <

php strlen mb_strlen计算中英文混排字符串长度_php技巧

比较strlen和mb_strlen 当字符全是英文字符的时候,两者是一样.这里主要比较一下,中英文混排的时候,两个计算结果.(测试时编码方式是UTF8) 复制代码 代码如下: <?php $str='中文a字1符'; echo strlen($str); echo '<br />'; echo mb_strlen($str,'UTF8'); //输出结果 //14 //6 ?> 结果分析:在strlen计算时,对待一个UTF8的中文字符是3个长度,所以"中文a字1符&q

PHP中英数字混排字符串的截取

 代码如下 复制代码 function smssubstr($string, $length) {  if(strlen($string) <= $length) {   return $string;   }  $strcut = '';  for($i = 0; $i < $length; $i++) {   $strcut .= ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];  }  return

搞定phpwind的静态化部署只需三步

这几天装PHPWIND,费了很多周折,最大的就是静态化部署问题. 所谓的静态化对于PHPWIND来说实质是伪静态. 什么意思呢? 比如某些已经实现静态化的PHPWIND论坛某页面:http://www.地址.com/bbs/post-htm-fid-4.html 实质呢是http://www.地址.com/bbs/post.php?id=4 也就是个解析问题,但是这样的话明显搜索引擎更喜欢HTML页面 即使是伪造的. 但是很多站长包括悟空软件的站长对PHP不是很熟悉.官方手册说的一堆搞得我云里雾

Word入门动画教程133:纵横混排

纵横混排与改变文字方向(参见Word入门动画教程128)不同,它可以在同一页面中,改变部分文本的 排列方向,由原来的纵向变为横向,原来的横向变为纵向,尤其适用于少量文字(例如日期).操作步骤 如下: 1.选择要改变方向的文本. 2.执行"格式"→"中文版式"→"纵横混排",打开 "纵横混排"对话框. 3.选中"适应行宽"复选项,可使文本旋转方向后自动压缩其高度与该行的高度相同. 4.单击"确定&q

css左图右内容(图文混排)的实现方法

先看效果图 列表实现图文混排"> 百度新闻首页的方案:  代码如下 复制代码 <table>  <tbody>  <tr>  <td class="topic-pic"><a href=""><img src=""></a></td>  <td class="topic-txt">-</td>

asp小偷程序中的字符串截取函数

函数|字符串|小偷程序 asp小偷程序中的字符串截取函数 以下是函数代码:'******************************************************************************** '    Function(公有) '    名称 :    字符串截取函数 '    作用 :    按指定首尾字符串截取内容(本函数为从左向右截取) '    参数 :    sContent ---- 被截取的内容 '        sStart ----