找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 601|回复: 0
打印 上一主题 下一主题

编写PHP程序检查字符串中的中文字符个数的实例分享

[复制链接]

3444

主题

3465

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
11142
跳转到指定楼层
楼主
发表于 2018-2-14 05:38:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            有时候我们需要计算一个字符串中包含的字数,对于纯英文字符串,字数等于字符串长度,用
strlen函数即可获得,但如果字符串中包含中文怎办?mb_strlen可以实现,但不幸没装扩展,那就自己实现一下吧。
php有一个扩展一般是必装的,我们可以使用mb_strlen来获取字符串中的字数,用法一般如下:
$len = mb_strlen("你是我的小苹果","utf-8");
如愿获得字符串长度:7.
如果没装mb扩展呢?自己实现一下吧。
我们要先明白一个事实:字符串是由字符组成的,而字符是由字节表示的,每个英文字符是一个字节,对应一个ascii码,英文字符的ascii码是小于128的,也就是十六进制的 0x80 .当一个字节的ascii码超过了127,那就说明当前字节不是一个完整的字符。
比如
$str = "你是我的小苹果";
中的$str{0}可以取到第一个字节,我们来看一下它是啥:
php > $str = "你是我的小苹果";
php > echo $str{0};

是个乱码,它只是
[U]复制代码[/U] 代码如下:你        
字的字节之一,也就是说,
[U]复制代码[/U] 代码如下:你
这个字符是由超过一个字节组成的,我们这样试试:
php > echo $str{0}.$str{1}.$str{2};

可以看到,将三个字节连在一起输出,就成了一个完整的
[U]复制代码[/U] 代码如下:你

至于这里为什么是三个字节,而不是两个或4个?这个取决于字符串的编码,我这里控制台默认是utf8编码的,在PHP中,一个utf8字符是用三个字节表达的,如果是gbk编码,则会是两个字节。至于编码和字节的关系,这个话题比较大,一篇说不完,请参考这篇文章:字符编码笔记:ascii,unicode和utf8 。
知道了这些,我们就可以自己编写一个字数检查的函数了,大致流程如下:
1.for循环遍历字节 2.判断字节编码是否 >= 0x80,是的话跳过N个字节
我写了个简单的函数,可以判断gbk或utf8字符串的长度,仅供参考:
= 0x80) {
      $i = $i + $step - 1;//之所以减去1,因为for循环本身还要$i++
    }
  }
  return $count;
}
echo mbstrlen(iconv("utf-8","gbk","你是我的小苹果"),"gbk");
echo mbstrlen("你是我的小苹果");
            
            
您可能感兴趣的文章:
  • php中计算中文字符串长度、截取中文字符串的函数代码
  • PHP中文处理 中文字符串截取(mb_substr)和获取中文字符串字数
  • 多个PHP中文字符串截取函数
  • php的GD库imagettftext函数解决中文乱码问题
  • php支持中文字符串分割的函数
  • php将金额数字转化为中文大写
  • php实现过滤字符串中的中文和数字实例
  • php精确的统计在线人数的方法
  • PHP使用redis实现统计缓存mysql压力的方法
  • php封装好的人民币数值转中文大写类
  • php阿拉伯数字转中文人民币大写
  • php简单统计在线人数的方法
  • php简单统计中文个数的方法
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端