dedecms字符串截取函数怎么用
dedecms字符串截取函数怎么用?
dedecms 的cn_substr_utf8字符串截取函数商榷
推荐学习:织梦cms
在phpsir看到的这篇文章,主要是说下dedecms 的cn_substr_utf8函数好像有些问题,研究dedecms的朋友可以看下
在dedecms里面 cn_substr_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 |
/** * utf-8中文截取,单字节截取模式 * * @access public * @param string $str 需要截取的字符串 * @param int $slen 截取的长度 * @param int $startdd 开始标记处 * @return string */ if ( ! function_exists('cn_substr_utf8')) { function cn_substr_utf8($str, $length, $start=0) { if(strlen($str) < $start+1) { return ''; } preg_match_all("/./su", $str, $ar); $str = ''; $tstr = ''; </p> <p> //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取 for ($i=0; isset($ar[0][$i]); $i++) { if(strlen($tstr) < $start) { $tstr .= $ar[0][$i]; } else { if(strlen($str) < $length + strlen($ar[0][$i]) ) { $str .= $ar[0][$i]; } else { break; } } } return $str; } } |
其中
代码如下:
1 |
if(strlen($str) < $length + strlen($ar[0][$i]) ) |
一行可能会造成截取后多了一个字符,可以考虑改为
代码如下:
1 |
if(strlen($str) < $length + strlen($ar[0][$i]) -1 ) |
测试代码如下
代码如下:
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 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 |
$f = "你好fasdfa你fasdf#e#"; $pos = strpos($f,'#e#'); var_dump($pos); var_dump(cn_substr_utf8($f,$pos)); var_dump(cn_substr_utf82($f,$pos)); </p> <p>function cn_substr($str, $slen, $startdd=0) { global $cfg_soft_lang; if($cfg_soft_lang=='utf-8') { return cn_substr_utf8($str, $slen, $startdd); } $restr = ''; $c = ''; $str_len = strlen($str); if($str_len < $startdd+1) { return ''; } if($str_len < $startdd + $slen || $slen==0) { $slen = $str_len - $startdd; } $enddd = $startdd + $slen - 1; for ($i=0;$i<$str_len;$i++) { if($startdd==0) { $restr .= $c; } else if($i > $startdd) { $restr .= $c; } </p> <p> if(ord($str[$i])>0x80) { if($str_len>$i+1) { $c = $str[$i].$str[$i+1]; } $i++; } else { $c = $str[$i]; } </p> <p> if($i >= $enddd) { if(strlen($restr)+strlen($c)>$slen) { break; } else { $restr .= $c; break; } } } return $restr; } </p> <p>function cn_substr_utf8($str, $length, $start=0) { if(strlen($str) < $start+1) { return ''; } preg_match_all("/./su", $str, $ar); </p> <p> $str = ''; $tstr = ''; </p> <p> //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取 for ($i=0; isset($ar[0][$i]); $i++) { if(strlen($tstr) < $start) { </p> <p> $tstr .= $ar[0][$i]; } else { </p> <p> if(strlen($str) < $length + strlen($ar[0][$i]) ) { </p> <p> $str .= $ar[0][$i]; } else { </p> <p> break; } } } return $str; } </p> <p>function cn_substr_utf82($str, $length, $start=0) { if(strlen($str) < $start+1) { return ''; } preg_match_all("/./su", $str, $ar); </p> <p> $str = ''; $tstr = ''; </p> <p> //为了兼容mysql4.1以下版本,与数据库varchar一致,这里使用按字节截取 for ($i=0; isset($ar[0][$i]); $i++) { if(strlen($tstr) < $start) { </p> <p> $tstr .= $ar[0][$i]; } else { </p> <p> if(strlen($str) < $length + strlen($ar[0][$i]) -1 ) // phpsir 加了 -1 { </p> <p> $str .= $ar[0][$i]; } else { </p> <p> break; } } } return $str; } |
以上就是dedecms字符串截取函数怎么用的详细内容,更多请关注织梦楼其它相关文章!
①本站所有织梦模板资源均来自用户分享和网络收集,如果侵犯了您的权益,请联系网站客服处理
②本站提供的织梦源码,均带数据及演示地址。可以在任一源码详情页查看演示地址。
③由于博主时间紧缺,所有模板源码不提供技术支持。仅部分收费原创源码提供售后
④如遇模板源码下载链接打不开或者有错误,请联系网站客服QQ指出纠正。
⑤人民币与金币汇率为1比1,即1元=1金币
织梦楼 » dedecms字符串截取函数怎么用
织梦楼 » dedecms字符串截取函数怎么用