加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

真正根据utf8编码的规律来进行截取字符串的函数(utf8版sub_str )

发布时间:2020-12-13 06:11:36 所属栏目:PHP教程 来源:网络整理
导读:div class="codetitle" a style="CURSOR: pointer" data="66547" class="copybut" id="copybut66547" onclick="doCopy('code66547')" 代码如下: div class="codebody" id="code66547" / 功能: 作用跟substr一样,除了它不会造成乱码 参数: 返回: / function

<div class="codetitle"><a style="CURSOR: pointer" data="66547" class="copybut" id="copybut66547" onclick="doCopy('code66547')"> 代码如下:<div class="codebody" id="code66547">
/
功能: 作用跟substr一样,除了它不会造成乱码
参数:
返回:
/
function utf8_substr( $str,$start,$length=null ){
// 先正常截取一遍.
$res = substr( $str,$length );
$strlen = strlen( $str );
/
接着判断头尾各6字节是否完整(不残缺) */
// 如果参数start是正数
if ( $start >= 0 ){
// 往前再截取大约6字节
$next_start = $start + $length; // 初始位置
$next_len = $next_start + 6 <= $strlen ? 6 : $strlen - $next_start;
$next_segm = substr( $str,$next_start,$next_len );
// 如果第1字节就不是 完整字符的首字节,再往后截取大约6字节
$prev_start = $start - 6 > 0 ? $start - 6 : 0;
$prev_segm = substr( $str,$prev_start,$start - $prev_start );
}
// start是负数
else{
// 往前再截取大约6字节
$next_start = $strlen + $start + $length; // 初始位置
$next_len = $next_start + 6 <= $strlen ? 6 : $strlen - $next_start;
$next_segm = substr( $str,再往后截取大约6字节.
$start = $strlen + $start;
$prev_start = $start - 6 > 0 ? $start - 6 : 0;
$prev_segm = substr( $str,$start - $prev_start );
}
// 判断前6字节是否符合utf8规则
if ( preg_match( '@^([x80-xBF]{0,5})[xC0-xFD]?@',$next_segm,$bytes ) ){
if ( !empty( $bytes[1] ) ){
$bytes = $bytes[1];
$res .= $bytes;
}
}
// 判断后6字节是否符合utf8规则
$ord0 = ord( $res[0] );
if ( 128 <= $ord0 && 191 >= $ord0 ){
// 往后截取,并加在res的前面.
if ( preg_match( '@[xC0-xFD][x80-xBF]{0,5}$@',$prev_segm,$bytes ) ){
if ( !empty( $bytes[0] ) ){
$bytes = $bytes[0];
$res = $bytes . $res;
}
}
}
return $res;
}

测试数据::
<div class="codetitle"><a style="CURSOR: pointer" data="58261" class="copybut" id="copybut58261" onclick="doCopy('code58261')"> 代码如下:<div class="codebody" id="code58261">
<?php
$str = 'dfjdjf测13f试65&2数据fdj(1就mfe&……就';
var_dump( utf8_substr( $str,22,12 ) ); echo '
';
var_dump( utf8_substr( $str,-6 ) ); echo '
';
var_dump( utf8_substr( $str,9,19,28,-6 ) ); echo '
';

显示结果::(截取无乱码,欢迎大家测试,提交bug)
string(12) "据fdj"
string(26) "据fdj(1就mfe&…"
string(13) "13f试65&2数"
string(12) "数据fd"
string(20) "dj(1就mfe&…"

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读