ホームページ >バックエンド開発 >PHPチュートリアル >PHPでの漢字変換:Unicode(UTF8)からGBKへ
PHP の漢字変換は常に面倒なことでした
このクラスには 4 つの組み込みフィルター「[dec];」、「[hex];」、「%u[hex]」、「utf8」があります変換」
ユーザーにとって使いやすく、フィルタリングをカスタマイズして好みの操作を行うこともできます
qswhU.php こちらからダウンロード
http://www.blueidea.com/user/qswh/qswhU.zip
class qswhU{
var $qswhData;
function qswhU($filename="qswhU.php"){
$this->qswhData=file($filename);
}
function decode($str,$pattern= 0){
$arr=array("/(w+);/iU","/((%ww)+)/i","/%u(w{4,5})/iU") ;
if( is_integer($pattern)){
if($pattern>=count($arr))die("無効な関数");
$pattern=$arr[$pattern];
}
return preg_replace_callback($ pattern,array( $this,"u2gb"),$str);
}
function u2gb($arr){
/******(秋水烏編 2002-8-15)******/
$ret="";$str=$arr[1 ];
if (preg_match_all("/%w{2}/",$str,$matches)){
for($i=0;$i
$arr=array("f0","e0","c0","0");
for($j= 0;$j
$chr=hexdec(substr($matches[0][$i],1 ))-hexdec ($arr[$j]);
while(++$j
if(strlen($str)==4){
$p=hexdec(substr($str,0,2))-0x4d;
$q= hexdec(substr($str,2))*4;
$ret.=chr(hexdec(substr($this->qswhData[$p],$q,2)));
$ret .=chr( hexdec(substr($this->qswhData[$p],$q+2,2)));
}else
$ret.=chr(hexdec($str));
}
}
else{
if(strto lower($str[0])=="x")
$str=substr($str,1);
else
if(strlen($str)!=4)$str=dechex ($str) ;
if(strlen($str)==4){
$p=hexdec(substr($str,0,2))-0x4d;
$q=hexdec(substr($str,2) ))*4 ;
$ret.=chr(hexdec(substr($this->qswhData[$p],$q,2)));
$ret.=chr(hexdec(substr($this-> ;qswhData[$ p],$q+2,2)));
}else
$ret.=chr(hexdec($str));
}
return $ret;
}
}
使用例
$qswh=new qswhU("qswhU.php");//ファイル名がqswhU.phpの場合パラメータは省略可能
echo "
効果は次のとおりです:
パラメータなし (デフォルトのフィルタリングは: [num];):
中国語 Abc
中国語 Abc
組み込みフィルタリングを呼び出します ( UTF トランスコーディング): 中国語!"#$ %&'()*+,/:;<=>?@[]^`{|}~%Abc
組み込みフィルター unescape(%u[num ]): 中国語 Abc
カスタム フィルター ([x +num]):中国語 Abc