php数组中文排序,文件格式一般用utf8,直接用asort排序不行。若是gbk和gb2312可以。这跟编码有关。gbk和gb2312本身的编码就是用拼音排序的。
function utf8_array_asort(&$array) {<BR>if(!isset($array) || !is_array($array)) {<BR> return false;<BR>}<BR>foreach($array as $k=>$v) {<BR> $array[$k] = iconv('UTF-8', 'GB2312',$v);<BR>}<BR>asort($array);<BR>foreach($array as $k=>$v) {<BR> $array[$k] = iconv('GB2312', 'UTF-8', $v);<BR>}<BR>return true;<BR>}
使用例子:
$abc = array('a'=>'猜', 'b'=>'我','c'=>'哦','d'=>'棍','e'=>'f','f'=>'爸','z'=>'州');<BR>utf8_array_asort($abc);<BR>print_r($abc);
但是使用这个函数发现,有些文字会出错,可能是utf8编码认不出某些字导致的“非法字符”,据了解GBK字符集比较大,换成GB本#文来源gaodai$ma#com搞$$代**码网$K,再加上IGNORE忽略掉不认识的字符 ,改成下面这样
private function utf8_array_asort(&$array) {<BR> if(!isset($array) || !is_array($array)) {<BR> return false;<BR> }<BR> foreach($array as $k=>$v) {<BR> $array[$k] = iconv('UTF-8', 'GBK//IGNORE',$v);<BR> }<BR> asort($array);<BR> foreach($array as $k=>$v) {<BR> $array[$k] = iconv('GBK', 'UTF-8//IGNORE', $v);<BR> }<BR> return true;<BR>}