Home >Backend Development >PHP Tutorial >strlen php strlen mb_strlen calculates the length of mixed Chinese and English strings

strlen php strlen mb_strlen calculates the length of mixed Chinese and English strings

WBOY
WBOYOriginal
2016-07-29 08:40:171314browse

Compare strlen and mb_strlen
When the characters are all English characters, they are the same. Here we mainly compare the two calculation results when Chinese and English are mixed. (The encoding method during testing is UTF8)

Copy the code The code is as follows:


$str='Chinese a character 1 character';
echo strlen($str);
echo '< ;br />';
echo mb_strlen($str,'UTF8');
//Output result
//14
//6
?>


Result analysis: When calculating strlen, treat a UTF8 Chinese characters are 3 in length, so the length of "Chinese a character 1 character" is 3*4+2=14
When calculating mb_strlen, if the internal code is selected to be UTF8, a Chinese character will be calculated as a length of 1 , so the length of "Chinese a character 1 character" is 6
About the placeholder calculation of Chinese and English mixed strings:
Using these two functions, you can jointly calculate the placeholder of a Chinese and English mixed string (a The occupancy of Chinese characters is 2, and the occupancy of English characters is 1). The calculation method is: if a mixed string has a Chinese character and b English character, the occupancy is:

Copy the code The code is as follows:


$str='Chinese a character 1 character';
//The calculation is as follows
echo (strlen($str) + mb_strlen($str,'UTF8')) / 2;
echo
// Output result
//10
?>


For example, the strlen($str) value of "Chinese a character 1 character" is 14, and the mb_strlen($str) value is 6, then you can calculate "Chinese a character 1 character" "The placeholder is 10.
Attached is an article on the website:
It's still a question about Chinese. PHP's built-in string length function strlen cannot correctly handle Chinese strings. It only gets the number of bytes occupied by the string. For GB2312 Chinese encoding, the value obtained by strlen is twice the number of Chinese characters, while for UTF-8 encoded Chinese, the difference is three times (under UTF-8 encoding, one Chinese character occupies 3 bytes).
Using the mb_strlen function can better solve this problem. The usage of mb_strlen is similar to strlen, except that it has a second optional parameter to specify the character encoding. For example, to get the UTF-8 string $str length, you can use mb_strlen($str,'UTF-8'). If the second parameter is omitted, PHP's internal encoding will be used. The internal encoding can be obtained through the mb_internal_encoding() function. It should be noted that mb_strlen is not a core function of PHP. Before using it, you need to make sure that php_mbstring.dll is loaded in php.ini, that is, make sure that the line "extension=php_mbstring.dll" exists and is not commented out, otherwise it will be undefined. function problem.

The above has introduced strlen php strlen mb_strlen to calculate the length of mixed Chinese and English strings, including the content of strlen. I hope it will be helpful to friends who are interested in PHP tutorials.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn