那就是使用php中的mb_strlen和strlen函数判断:分别使用以上两个函数以当前编码测出字符的返回值,然后比较返回值。返回值相等的为纯英文、纯数字、英数混排;返回值不等,且strlen返回值可被mb_strlen整除的为纯汉字。返回值不等,且strlen返回值不可被mb_strlen整除的为英汉或数汉混排。
多么奇妙的函数,多么有意思的想法,多么精彩的例子,在下面,呵呵。
例子,
$value) { $x = mb_strlen($value,'gb2312'); $y = strlen($value); echo $strarray[$key].' '.$x.' '.$y.''; } ?>
输出结果:hello 5 5123456 6 6123hello 8 8你好 2 4123你好 5 7hello你好 7 9123hello你好 10 12
php没有直接函数来判断一个字符串是否是纯英文或纯汉字以及汉英混合,只能自己写函数。要想实现此功能就必需对字符集汉字编码占位进行了解,就目前国内比较常用的字符集当属utf8与gbk了。
utf8每个汉字等于3个长度;gbk每个汉字等于2个长度;
根据以上汉字与英文的差异,可以使用mb_strlen函数与strlen函数分别计算出两组长度数字,然后根据规律进行运算即可判断出字符串的类型了。
1、utf-8的例子
2、gbk方法的例子
