コードをコピー コードは次のとおりです:
/* UTF-8 漢字切り捨てプログラム*/
$str = "123 これはテスト文字列です";
$str1 = "()()"
echo subUTF8str($str,0,3)."
; 🎜>echo subUTF8str($str,0,4)."
";
echo subUTF8str($str1,0,4)."
echo subUTF8str($str1, 0,10 )."
";
function subUTF8str($str,$start=0,$length=80){
$cur_len = 0; //人間が理解できる文字列長
$all_len = strlen($str); //マシンは文字列の長さを理解します
if($length > $all_len)
{
return $str;
for($i = 0 ;$i < $all_len;)
{
if($cur_len == $start)
{
break;
}
if (ord($str[$ i ]) > 127)
{
$i = 3;
}else{
$i = 1;
$ start_pos = $i;
$temp_pos = $cur_len;
for(;$cur_len - $temp_pos
if($i >= $all_len)
break;
if (ord($str[$i]) > 127)
{
$i = 3;
$i = 1; > }
$cur_len ;
}
$end_pos = $i;
return substr($str,$start_pos,$end_pos);
実際、PHP にはマルチ文字セットでのネイティブ文字インターセプト スキームがあり、ええと、次のようになります...囧..
マルチバイト文字列関数関数ファミリーでは、
string mb_substr ( string $str , int $start [, int $length [, string $encoding ]] ) は string
int mb_strlen ( string $str [, string $encoding ] ) をインターセプトするために使用され、文字列の長さを返します。 🎜>... .
詳細については、PHP マニュアルを確認してください。