我的数据源是utf8格式的 但是我要对这些数据做排序,由于是中文,我将其转换为gbk或gbk2312,但是排序出了部分不准确的问题
我是用php的array_multi_sort方法排序的
排序结果中会出现这样的问题黑框里这些数据很明显按照拼音降序排列不正确 但是后面的数据却都是合适的,不知道这是什么原因?还是说gbk的库不够全?
补充一段测试代码
$array = array("鹭","昊","瀚","骅","众","怡","萃","重","恺","鑫");
foreach($array as $val...
php数组中文排序,文件格式一般用utf8,直接用asort排序不行。若是gbk和gb2312可以。这跟编码有关。gbk和gb2312本身的编码就是用拼音排序的。 代码如下:function utf8_array_asort(&$array) {if(!isset($array) || !is_array($array)) { return false;}foreach($array as $k=>$v) { $array[$k] = iconv('UTF-8', 'GB2312',$v);}asort($array);foreach($array as $k=>$v) { $array[$k] = iconv('GB2312', 'UTF-8', $v);}return t...
PHP中使用asort进行中文排序失效的问题处理,
PHP中有非常方便的对数组进行重新排序的方法——asort,关于asort的使用方法可以看 这里 。但是asort对含有中文key的数组进行排序时,有时候并不是按照字母顺序。这主要是编码问题,如果编码为UTF-8,则不会按照字母顺序来排,解决方法是先转换成GBK编码,排序完再转回UTF-8.
示例:有一个数组$pass,结构类似为
Array
([0] => stdClass Object([username] => 张三[password] => DQ9uq...
PHP与MYSQL中UTF8编码的中文排序实例,
本文实例讲述了PHP与MYSQL中UTF8编码的中文排序方法,分享给大家供大家参考。具体实现方法如下:
一般来说,中文共有三种排序方式:
1.根据拼音排序;
2.根据笔画排序;
3.根据偏旁排序。
系统的默认排序方式为拼音排序了,这个也是我们常用的,下面介绍的就是按拼音排序了
1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行。用gbk和gb2312可以。这跟几种格式...
php数组中文排序,文件格式一般用utf8,直接用asort排序不行。若是gbk和gb2312可以。这跟编码有关。gbk和gb2312本身的编码就是用拼音排序的。 代码如下:function utf8_array_asort(&$array) {if(!isset($array) || !is_array($array)) { return false;}foreach($array as $k=>$v) { $array[$k] = iconv('UTF-8', 'GB2312',$v);}asort($array);foreach($array as $k=>$v) { $array[$k] = iconv('GB2312', 'UTF-8', $v);}return t...
php数组中文排序,文件格式一般用utf8,直接用asort排序不行。若是gbk和gb2312可以。这跟编码有关。gbk和gb2312本身的编码就是用拼音排序的。 代码如下:function utf8_array_asort(&$array) {if(!isset($array) || !is_array($array)) { return false;}foreach($array as $k=>$v) { $array[$k] = iconv('UTF-8', 'GB2312',$v);}asort($array);foreach($array as $k=>$v) { $array[$k] = iconv('GB2312', 'UTF-8', $v);}return t...
PHP中有非常方便的对数组进行重新排序的方法——asort,关于asort的使用方法可以看 这里 。但是asort对含有中文key的数组进行排序时,有时候并不是按照字母顺序。这主要是编码问题,如果编码为UTF-8,则不会按照字母顺序来排,解决方法是先转换成GBK编码,排序完再转回UTF-8.
示例:有一个数组$pass,结构类似为Array
([0] => stdClass Object([username] => 张三[password] => DQ9uqQW2+UudOsZpQMnyvGG9L+RHZB6LRzBVDvAEL9uOBNf2z...
本文实例讲述了PHP与MYSQL中UTF8编码的中文排序方法,分享给大家供大家参考。具体实现方法如下:
一般来说,中文共有三种排序方式:
1.根据拼音排序;
2.根据笔画排序;
3.根据偏旁排序。
系统的默认排序方式为拼音排序了,这个也是我们常用的,下面介绍的就是按拼音排序了
1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行。用gbk和gb2312可以。这跟几种格式的编码有关系。gbk和gb2312本身的编码就...
PHP中有非常方便的对数组进行重新排序的方法——asort,关于asort的使用方法可以看 这里 。但是asort对含有中文key的数组进行排序时,有时候并不是按照字母顺序。这主要是编码问题,如果编码为UTF-8,则不会按照字母顺序来排,解决方法是先转换成GBK编码,排序完再转回UTF-8.
示例:有一个数组$pass,结构类似为
Array
([0] => stdClass Object([username] => 张三[password] => DQ9uqQW2+UudOsZpQMnyvGG9L+RHZB6LRzBVDvAEL9uOBNf2...
本文实例讲述了PHP与MYSQL中UTF8编码的中文排序方法,分享给大家供大家参考。具体实现方法如下:
一般来说,中文共有三种排序方式:
1.根据拼音排序;
2.根据笔画排序;
3.根据偏旁排序。
系统的默认排序方式为拼音排序了,这个也是我们常用的,下面介绍的就是按拼音排序了
1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行。用gbk和gb2312可以。这跟几种格式的编码有关系。gbk和gb2312本身的编码就...
PHP中有非常方便的对数组进行重新排序的方法——asort,关于asort的使用方法可以看 这里 。但是asort对含有中文key的数组进行排序时,有时候并不是按照字母顺序。这主要是编码问题,如果编码为UTF-8,则不会按照字母顺序来排,解决方法是先转换成GBK编码,排序完再转回UTF-8.
示例:有一个数组$pass,结构类似为
Array
([0] => stdClass Object([username] => 张三[password] => DQ9uqQW2+UudOsZpQMnyvGG9L+RHZB6LRzBVDvAEL9uOBNf2...
本文实例讲述了PHP与MYSQL中UTF8编码的中文排序方法,分享给大家供大家参考。具体实现方法如下:
一般来说,中文共有三种排序方式:
1.根据拼音排序;
2.根据笔画排序;
3.根据偏旁排序。
系统的默认排序方式为拼音排序了,这个也是我们常用的,下面介绍的就是按拼音排序了
1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行。用gbk和gb2312可以。这跟几种格式的编码有关系。gbk和gb2312本身的编码就...
1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行。用gbk和gb2312可以。这跟几种格式的编码有关系。gbk和gb2312本身的编码就是用拼音排序的。
代码如下
function utf8_array_asort(&$array)
{
if(!isset($array) || !is_array($array))
{
return false;
}
foreach($array as $k=>$v)
{
$array[$k] = iconv(UTF-8, GBK//IGNORE,$v);
}
asort($array);
foreach($array as $k=>$v)
{
$array[$k] = ico...
php数组中文排序,文件格式一般用utf8,直接用asort排序不行。若是gbk和gb2312可以。这跟编码有关。gbk和gb2312本身的编码就是用拼音排序的。 代码如下:function utf8_array_asort(&$array) {if(!isset($array) || !is_array($array)) { return false;}foreach($array as $k=>$v) { $array[$k] = iconv('UTF-8', 'GB2312',$v);}asort($array);foreach($array as $k=>$v) { $array[$k] = iconv('GB2312', 'UTF-8', $v);}return t...