|
復(fù)制代碼 代碼如下:
<?php
//編碼UTF-8
echo strlen('測(cè)試文字a測(cè)試文字');
echo '-';
echo mb_strlen('測(cè)試文字a測(cè)試文字','utf-8');
?>
輸出:25-9
GB2312的中文字符串是二個(gè)字節(jié)
復(fù)制代碼 代碼如下:
<?php
//編碼GB2312
echo strlen('測(cè)試文字a測(cè)試文字');
echo '-';
echo mb_strlen('測(cè)試文字a測(cè)試文字','Gb2312');
?>
輸出:17-9
在Mysql數(shù)據(jù)庫(kù)(5.1以后的版本)中,如果字段類型為varchar(10)則可插入10個(gè)字符(不是字節(jié));
所以在判斷字符串的長(zhǎng)度時(shí)需要根據(jù)文檔編碼來(lái)區(qū)分。
符一個(gè)簡(jiǎn)單的UTF-8下字符串截取(按字符個(gè)數(shù)截取)
復(fù)制代碼 代碼如下:
<?
/*
* UTF-8字符串截取
* $str 要截取的字串
* $start 截取起始位置
* $length 截取長(zhǎng)度
*/
function cutStr($str,$start,$length) {
$restr = '';
$j = 0;
$end = $length + $start - 1;
$plen = strlen($str);
for($i=0;$i<$plen;$i++) {
$restr .= ord($str[$i])>127 ? $str[$i].$str[++$i].$str[++$i] : $str[$i];
$j++;
if ($j < $start){$restr = '';}
if ($j >= $end){break;}
}
$restr .='';
return $restr;
}
$str = '中新網(wǎng)9月24日電 二十國(guó)集團(tuán)(G20)領(lǐng)導(dǎo)人第三次金融峰會(huì)今日將在美國(guó)匹茲堡召開(kāi)。';
echo $str;
echo '<br>';
echo utf8_substr($str,0,25);
echo '<br>';
?>
php技術(shù):php 不同編碼下的字符串長(zhǎng)度區(qū)分,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。