首页 后端开发 php教程 真正根据utf8编码的规律来进行截取字符串的函数(utf8版sub_str )_php技巧

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

May 17, 2016 am 09:08 AM
utf8 截取字符串

复制代码 代码如下:

/*
* 功能: 作用跟substr一样,除了它不会造成乱码
* 参数:
* 返回:
*/
function utf8_substr( $str , $start , $length=null ){
// 先正常截取一遍.
$res = substr( $str , $start , $length );
$strlen = strlen( $str );
/* 接着判断头尾各6字节是否完整(不残缺) */
// 如果参数start是正数
if ( $start >= 0 ){
// 往前再截取大约6字节
$next_start = $start + $length; // 初始位置
$next_len = $next_start + 6 $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 $next_segm = substr( $str , $next_start , $next_len );
// 如果第1字节就不是 完整字符的首字节, 再往后截取大约6字节.
$start = $strlen + $start;
$prev_start = $start - 6 > 0 ? $start - 6 : 0;
$prev_segm = substr( $str , $prev_start , $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 ){
// 往后截取 , 并加在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;
}

测试数据::
复制代码 代码如下:

$str = 'dfjdjf测13f试65&2数据fdj(1就mfe&……就';
var_dump( utf8_substr( $str , 22 , 12 ) ); echo '
';
var_dump( utf8_substr( $str , 22 , -6 ) ); echo '
';
var_dump( utf8_substr( $str , 9 , 12 ) ); echo '
';
var_dump( utf8_substr( $str , 19 , 12 ) ); echo '
';
var_dump( utf8_substr( $str , 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&…"
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

utf8编码汉字占多少字节 utf8编码汉字占多少字节 Feb 21, 2023 am 11:40 AM

utf8编码汉字占3个字节。在UTF-8编码中,一个中文等于三个字节,一个中文标点占三个字节;而在Unicode编码中,一个中文(含繁体)等于两个字节。UTF-8使用1~4字节为每个字符编码,一个US-ASCIl字符只需1字节编码,带有变音符号的拉丁文、希腊文、西里尔字母、亚美尼亚语、希伯来文、阿拉伯文、叙利亚文等字母则需要2字节编码。

如何在Go语言中截取字符串 如何在Go语言中截取字符串 Mar 13, 2024 am 08:33 AM

Go语言是一种强大且灵活的编程语言,它提供了丰富的字符串处理功能,包括字符串截取。在Go语言中,我们可以使用切片(slice)来截取字符串。接下来,将详细介绍如何在Go语言中截取字符串,并附上具体的代码示例。一、使用切片截取字符串在Go语言中,可以使用切片表达式来截取字符串的一部分。切片表达式的语法如下:slice:=str[start:end]其中,s

go语言怎么截取字符串 go语言怎么截取字符串 Jan 12, 2023 pm 04:02 PM

截取方法:1、截取单个字符,语法“string[index]”,其中“string”表示源字符串,“index”表示要获取的字符下标;2、截取子串,语法“string[start : end]”,其中“start”表示要截取的第一个字符所在的索引(截取时包含该字符),“end”表示要截取的最后一个字符所在的索引(不包含该字符);3、获取整个字符串,语法“string[:]”。

如何使用MySQL中的LEFT函数截取字符串的左边部分 如何使用MySQL中的LEFT函数截取字符串的左边部分 Jul 12, 2023 pm 01:37 PM

如何使用MySQL中的LEFT函数截取字符串的左边部分在数据库管理系统中,经常会遇到需要从字符串中截取某部分的情况。MySQL提供了许多内置的字符串函数,其中包括LEFT函数,它可以用于截取字符串的左边部分。LEFT函数的语法如下:LEFT(str,length)其中,str是要被截取的字符串,length是要截取的长度。接下来,我们将通过代码示例来演示如

node utf8汉字乱码怎么办 node utf8汉字乱码怎么办 Feb 08, 2023 am 10:29 AM

node utf8汉字乱码的解决办法:1、通过“typeof”查看“SarchName”的类型;2、使用“Name=iconv.decode(name,'gbk')”方式转换编码为utf8即可。

PHP中的substr()函数:如何截取字符串的一部分 PHP中的substr()函数:如何截取字符串的一部分 Nov 03, 2023 am 10:43 AM

PHP中的substr()函数:如何截取字符串的一部分,需要具体代码示例在PHP编程中,字符串的处理是非常常见的操作之一。而截取字符串的一部分则是处理字符串时经常遇到的需求。在PHP中,我们可以使用内置的substr()函数来截取字符串的一部分。本文将详细介绍substr()函数的用法,并给出具体的代码示例。substr()函数的基本用法如下:string

利用MySQL的LEFT函数截取字符串的指定长度 利用MySQL的LEFT函数截取字符串的指定长度 Jul 25, 2023 pm 05:04 PM

利用MySQL的LEFT函数截取字符串的指定长度在MySQL中,我们经常需要对字符串进行截取操作,以满足特定需求。其中,LEFT函数是一个非常实用的函数,可以截取字符串的指定长度。本文将介绍如何使用MySQL的LEFT函数进行字符串截取,并给出代码示例。首先,我们需要了解一下LEFT函数的语法。LEFT函数的基本语法如下:LEFT(string,lengt

MySQL中如何使用RIGHT函数截取字符串的右边部分 MySQL中如何使用RIGHT函数截取字符串的右边部分 Jul 12, 2023 am 10:20 AM

MySQL中如何使用RIGHT函数截取字符串的右边部分在MySQL中,RIGHT函数是用来截取字符串右边部分的函数。它接受两个参数:待截取的字符串和待截取的长度,返回一个包含指定长度的字符串。使用RIGHT函数可以非常方便地获取字符串的右边部分。下面我们将通过代码示例来演示如何使用RIGHT函数。首先,我们需要创建一个示例数据表,用于存储待截取的字符串。CR

See all articles