欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql 字符串長(zhǎng)度計(jì)算實(shí)現(xiàn)代碼(gb2312+utf8)

 更新時(shí)間:2011年12月16日 16:54:13   作者:  
PHP對(duì)中文字符串的處理一直困擾于剛剛接觸PHP開(kāi)發(fā)的新手程序員。下面簡(jiǎn)要的剖析一下PHP對(duì)中文字符串長(zhǎng)度的處
PHP對(duì)中文字符串的處理一直困擾于剛剛接觸PHP開(kāi)發(fā)的新手程序員。下面簡(jiǎn)要的剖析一下PHP對(duì)中文字符串長(zhǎng)度的處理:

PHP自帶的函數(shù)如strlen()、mb_strlen()都是通過(guò)計(jì)算字符串所占字節(jié)數(shù)來(lái)統(tǒng)計(jì)字符串長(zhǎng)度的,一個(gè)英文字符占1字節(jié)。例:

$enStr = 'Hello,China!';
echo strlen($enStr); // 輸出:12

而中文則不然,做中文網(wǎng)站一般會(huì)選擇兩種編碼:gbk/gb2312或是utf-8。utf-8能兼容更多的字符,所以受到很多站長(zhǎng)的喜愛(ài)。gbk與utf-8對(duì)中文的編碼不同,導(dǎo)致中文在gbk與utf-8編碼下所占字節(jié)也有差異。

gbk編碼下每個(gè)中文字符所占字節(jié)為2,例:

$zhStr = '您好,中國(guó)!';
echo strlen($zhStr); // 輸出:12

utf-8編碼下每個(gè)中文字符所占字節(jié)為3,例:

$zhStr = '您好,中國(guó)!';
echo strlen($zhStr); // 輸出:18

那么如何計(jì)算這組中文字符串的長(zhǎng)度呢?有人可能會(huì)說(shuō)gbk下獲取中文字符串長(zhǎng)度除以2,utf-8編碼下除以3不就行了嗎?但是您要考慮字符串并不老實(shí),99%的情況會(huì)以中英混合的情況出現(xiàn)。

這是WordPress中的一段代碼,主要思想就是先用正則將字符串分解為個(gè)體單元,然后再計(jì)算單元的個(gè)數(shù)即字符串的長(zhǎng)度,代碼如下(只能處理utf-8編碼下的字符串):
復(fù)制代碼 代碼如下:

$zhStr = '您好,中國(guó)!';
$str = 'Hello,中國(guó)!';

// 計(jì)算中文字符串長(zhǎng)度
function utf8_strlen($string = null) {
// 將字符串分解為單元
preg_match_all("/./us", $string, $match);
// 返回單元個(gè)數(shù)
return count($match[0]);
}
echo utf8_strlen($zhStr); // 輸出:6
echo utf8_strlen($str); // 輸出:9

utf8_strlen – 獲得UTF8編碼的字符串的長(zhǎng)度
復(fù)制代碼 代碼如下:

/*
* 用于UTF8編碼的程序
* 獲得字符串的長(zhǎng)度,一個(gè)中文表示3個(gè)長(zhǎng)度
* itlearner注釋
*/
function utf8_strlen($str) {
$count = 0;
for($i = 0; $i < strlen($str); $i++){
$value = ord($str[$i]);
if($value > 127) {
$count++;
if($value >= 192 && $value <= 223) $i++;
elseif($value >= 224 && $value <= 239) $i = $i + 2;
elseif($value >= 240 && $value <= 247) $i = $i + 3;
else die('Not a UTF-8 compatible string');
}
$count++;
}
return $count;
}

相關(guān)文章

  • MySQL的WHERE語(yǔ)句中BETWEEN與IN的使用教程

    MySQL的WHERE語(yǔ)句中BETWEEN與IN的使用教程

    這篇文章主要介紹了MySQL的WHERE語(yǔ)句中BETWEEN與IN的使用教程,是MySQL入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-12-12
  • 登錄mysql報(bào)錯(cuò)Can‘t connect to MySQL server on ‘localhost:3306‘ (10061)解決方法

    登錄mysql報(bào)錯(cuò)Can‘t connect to MySQL server&n

    這篇文章主要給大家介紹了登錄mysql報(bào)錯(cuò) Can‘t connect to MySQL server on ‘localhost:3306‘ (10061)解決方法,文中有詳細(xì)的解決步驟,需要的朋友可以參考下
    2023-09-09
  • MySQL中使用MD5加密的實(shí)現(xiàn)

    MySQL中使用MD5加密的實(shí)現(xiàn)

    本文主要介紹了MySQL中使用MD5加密的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • MySQL里實(shí)現(xiàn)類(lèi)似SPLIT的分割字符串的函數(shù)

    MySQL里實(shí)現(xiàn)類(lèi)似SPLIT的分割字符串的函數(shù)

    SQL對(duì)字符串的處理能力比較弱,比如我要循環(huán)遍歷象1,2,3,4,5這樣的字符串,如果用數(shù)組的話(huà),遍歷很簡(jiǎn)單,但是T-SQL不支持?jǐn)?shù)組,所以處理下來(lái)比較麻煩
    2012-09-09
  • Mysql之如何根據(jù).frm和.idb文件恢復(fù)表結(jié)構(gòu)

    Mysql之如何根據(jù).frm和.idb文件恢復(fù)表結(jié)構(gòu)

    這篇文章主要介紹了Mysql之如何根據(jù).frm和.idb文件恢復(fù)表結(jié)構(gòu)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Linux下安裝MySQL8.0.11的教程

    Linux下安裝MySQL8.0.11的教程

    這篇文章主要介紹了Linux下安裝MySQL8.0.11的教程,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-12-12
  • MYSQL命令行導(dǎo)入導(dǎo)出數(shù)據(jù)庫(kù)詳解

    MYSQL命令行導(dǎo)入導(dǎo)出數(shù)據(jù)庫(kù)詳解

    這篇文章主要詳細(xì)介紹了MYSQL命令行進(jìn)行導(dǎo)入導(dǎo)出數(shù)據(jù)庫(kù)操作的方法,并且分win系統(tǒng)和Linux系統(tǒng)介紹了mysql備份和還原的方法,非常的詳細(xì),希望對(duì)大家能有所幫助
    2014-09-09
  • mysql回表查詢(xún)是什么,回表查詢(xún)的使用

    mysql回表查詢(xún)是什么,回表查詢(xún)的使用

    這篇文章主要介紹了mysql回表查詢(xún)是什么,回表查詢(xún)的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。
    2022-11-11
  • MySQL 的啟動(dòng)選項(xiàng)和系統(tǒng)變量實(shí)例詳解

    MySQL 的啟動(dòng)選項(xiàng)和系統(tǒng)變量實(shí)例詳解

    這篇文章主要介紹了MySQL 的啟動(dòng)選項(xiàng)和系統(tǒng)變量,結(jié)合實(shí)例形式詳細(xì)分析了MySQL 啟動(dòng)選項(xiàng)和系統(tǒng)變量具體原理、功能、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-05-05
  • mysql聚合統(tǒng)計(jì)數(shù)據(jù)查詢(xún)緩慢的優(yōu)化方法

    mysql聚合統(tǒng)計(jì)數(shù)據(jù)查詢(xún)緩慢的優(yōu)化方法

    這篇文章主要給大家介紹了關(guān)于mysql聚合統(tǒng)計(jì)數(shù)據(jù)查詢(xún)緩慢的優(yōu)化方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02

最新評(píng)論