for
ループ内の英語の文字から中国語を分離する方法は?
これはコードです:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<?php
function filter_ch($char)
{
return $char;
}
function filter_en($char)
{
return $char;
}
$str='Hello 你怎么样? How are you?';
$english='';
$chinese='';
for ($i=0;$i<strlen($str);$i++)
{
$char = substr($str, $i, 1);
if(preg_match('/\p{Han}+/u', $char))
{//if chinese
$chinese.=filter_ch($char);
}
else
{//if english
$english.=filter_en($char);
}
}
echo 'chinese: '.$chinese.'<br>';
echo 'english: '.$english.'<br>';
?>
</body>
</html>
これは結果です:
chinese:
english: english: Hello 你怎么样? How are you?
私の望ましい結果:
chinese: 你怎么样?
english: Hello How are you?