substr() 函数返回字符串的一部分。
语法
substr(string,start,length)
例子 1
代码如下 | 复制代码 |
echo substr("Hello world!",6); 输出: world! |
例子2
代码如下 | 复制代码 |
echo substr('中国文',1); |
结果就是筹码了,后来才知道中文与英文的区别在于内编码了,一个网站这样说到substr函数在截取字符时是按字节来截取的,中文字符在GB2312编码时为2个字节,utf-8编码时为3个字节,所以截取指定长度的字符串时如果截断了汉字,那么返回的结果显示出来便会出现乱码
解决办法
1、利用mb_substr来截取
代码如下 | 复制代码 |
$str = '这样一来我的字符串就不会有乱码^_^'; echo "mb_substr:" . mb_substr($str, 0, 7, 'utf-8'); echo "mb_strcut:" . mb_strcut($str, 0, 6, 'utf-8'); |
但是如果要使用mb_substr截取我们需要使用使用mbstring扩展库,如果没有权限的朋友我们就可参考下面函数
代码如下 | 复制代码 |
function msubstr($str, $start, $len) { |