1.substr(源字符串,其实位置[,长度])-截取字符串返回部分字符串
- php
- $str ="itmop.com";
- echo substr($str, 2); //mop.com
- echo substr($str, 2,3); //mop
- echo substr($str, -2); //om 负数从结尾开始取
- ?>
但是当你截取中文字符串的时候很容易出现乱码,因为一个汉字是两个字节,而一个英文字母是一个字节。解决办法如下:
2.mb_substr(),使用方法和substr相同,不过要开启php.ini里面extension=php_mbstring.dll扩展,不用担心,一般的空间商
都会开启这个扩展的。
- php
- echo mb_substr("php点点通", 1,3,"UTF-8"); //hp点
- ?>
网上也有很多中文字符串截取教程,实现起来比较复杂,感觉还是用php自带的函数实现起来比较好。整理的网络资料(php代码)如下:
(1)截取GB2312中文字符串
- php
- //截取GB2312中文字符串
- function mysubstr($str, $start, $len) {
- $tmpstr = "";
- $strlen = $start + $len;
- for($i = 0; $i < $strlen; $i++) {
- if(ord(substr($str, $i, 1)) > 0xa0) {
- $tmpstr .= substr($str, $i, 2);
- $i++;
- } else
- $tmpstr .= substr($str, $i, 1);
- }
- return $tmpstr;
- }
- echo mysubstr("php点点通", 1, 5); //php点
- ?>
(2)截取utf8编码的多字节字符串
- php
- //截取utf8字符串
- function utf8Substr($str, $from, $len)
- {
- return preg_replace('#^(?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,'.$from.'}'.
- '((?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,'.$len.'}).*#s',
- '$1',$str);
- }
- echo utf8Substr("php点点通", 1, 5); //hp点点通
- ?>
(3)支持 utf-8、gb2312都支持的汉字截取函数
- php
- //同时支持 utf-8、gb2312都支持的