在PHP中,函數strlen()返回字符串的長度。函數原型如下: 復制代碼 代碼如下: int strlen(string string_input); 參數string_input為要處理的字符串。

strlen()函數返回字符串所占的 " /> 久久影院一区二区三区,丁香5月婷婷久久,国产成人aaa

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

PHP字符串長度計算 - strlen()函數使用介紹

strlen()函數和mb_strlen()函數

php中,函數strlen()返回字符串的長度。函數原型如下:
復制代碼 代碼如下:
int strlen(string string_input);

參數string_input為要處理的字符串。

strlen()函數返回字符串所占的字節長度,一個英文字母、數字、各種符號均占一個字節,它們的長度均為1。一個中午字符占兩個字節,所以一個中午字符的長度是2。例如
復制代碼 代碼如下:
<?php
echo strlen("www.sunchis.com");
echo strlen("三知開發網");
?>

“echo strlen("www.sunchis.com");”的運行結果:15

“echo strlen("三知開發網");”的運行結果:15

這里有一個疑問,一個中文字符不是占2個字節嗎?“三知開發網”,明明是五個漢字,運行的結果怎么會是15?

原因出在這里:strlen()計算時,對于一個UTF-8的中文字符,會把它當做長度為3來處理。當出現中英文混排的情況下,怎么準確的計算字符串的長度呢?這里,得引入另外一個函數mb_strlen()。mb_strlen()函數的用法與strlen()幾乎一摸一樣,只是多了一個指定字符集編碼的參數。函數原型為:
復制代碼 代碼如下:
int mb_strlen(string string_input, string encode);

php內置的字符串長度函數strlen無法正確處理中文字符串,它得到的只是字符串所占的字節數。對于GB2312的中文編碼,strlen得到的值是漢字個數的2倍,而對于UTF-8編碼的中文,就是3倍的差異了(在UTF-8編碼下,一個漢字占3個字節)。 因此,下面的代碼能準確計算出中文字符串的長度:
復制代碼 代碼如下:
<?php
$str = "三知sunchis開發網";
echo strlen($str)."<br>"; //結果:22
echo mb_strlen($str,"UTF8")."<br>"; //結果:12
$strlen = (strlen($str)+mb_strlen($str,"UTF8"))/2;
echo $strlen; //結果:17
?>

原理分析:

strlen()計算時,對待UTF-8的中文字符長度是3,所以“三知sunchis開發網”的長度為5×3+7×1=22
在mb_strlen計算時,選定內碼為UTF8,則會將一個中文字符當作長度1來計算,所以“三知sunchis開發網”長度為5×1+7×1=12

剩下的就是純數學問題了,在此就不 主站蜘蛛池模板: 通渭县| 巫山县| 定襄县| 敦煌市| 丰都县| 新野县| 宜丰县| 临汾市| 米林县| 上蔡县| 竹溪县| 任丘市| 武夷山市| 永济市| 株洲县| 胶州市| 南漳县| 大港区| 南汇区| 大余县| 阿拉善左旗| 渭南市| 绥中县| 哈尔滨市| 汝南县| 旌德县| 通州区| 枣阳市| 东乌珠穆沁旗| 仙桃市| 凤台县| 乌鲁木齐县| 盐山县| 鹤山市| 昌宁县| 霍城县| 天镇县| 华蓥市| 白山市| 江西省| 三明市|