有时候我们需要计算一个字符串中包含的字数,对于纯英文字符串,字数等于字符串长度,用
strlen函数即可获得,但如果字符串中包含中文怎办?mb_strlen可以实现,但不幸没装扩展,那就自己实现一下吧。
php有一个扩展一般是必装的,我们可以使用mb_strlen来获取字符串中的字数,用法一般如下:
1
|
$len = mb_strlen( "你是我的小苹果" , "utf-8" ); |
如愿获得字符串长度:7.
如果没装mb扩展呢?自己实现一下吧。
我们要先明白一个事实:字符串是由字符组成的,而字符是由字节表示的,每个英文字符是一个字节,对应一个ascii码,英文字符的ascii码是小于128的,也就是十六进制的 0x80 .当一个字节的ascii码超过了127,那就说明当前字节不是一个完整的字符。
比如
1
|
$str = "你是我的小苹果" ; |
中的$str{0}可以取到第一个字节,我们来看一下它是啥:
1
2
3
|
php > $str = "你是我的小苹果" ; php > echo $str {0}; |
这个字符是由超过一个字节组成的,我们这样试试:
1
|
php > echo $str {0}. $str {1}. $str {2}; |
至于这里为什么是三个字节,而不是两个或4个?这个取决于字符串的编码,我这里控制台默认是utf8编码的,在PHP中,一个utf8字符是用三个字节表达的,如果是gbk编码,则会是两个字节。至于编码和字节的关系,这个话题比较大,一篇说不完,请参考这篇文章:字符编码笔记:ascii,unicode和utf8 。
知道了这些,我们就可以自己编写一个字数检查的函数了,大致流程如下:
1.for循环遍历字节 2.判断字节编码是否 >= 0x80,是的话跳过N个字节
我写了个简单的函数,可以判断gbk或utf8字符串的长度,仅供参考:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
<?php { if (( $len = strlen ( $str )) == 0) { return 0; } $encoding = strtolower ( $encoding ); if ( $encoding == "utf8" or $encoding == "utf-8" ) { $step = 3; } elseif ( $encoding == "gbk" or $encoding == "gb2312" ) { $step = 2; } else { return false; } $count = 0; for ( $i =0; $i < $len ; $i ++) { $count ++; //如果字节码大于127,则根据编码跳几个字节 if (ord( $str { $i }) >= 0x80) { $i = $i + $step - 1; //之所以减去1,因为for循环本身还要$i++ } } return $count ; } echo mbstrlen(iconv( "utf-8" , "gbk" , "你是我的小苹果" ), "gbk" ); echo mbstrlen( "你是我的小苹果" ); |
© 版权声明
本文刊载的所有内容,包括文字、图片、音频、视频、软件、程序、以及网页版式设计等部门来源于互联网,版权均归原作者所有!本网站提供的内容服务于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
联系信息:邮箱aoxolcom@163.com或见网站底部。
联系信息:邮箱aoxolcom@163.com或见网站底部。
THE END
请登录后发表评论
注册
社交帐号登录