ホームページ  >  記事  >  バックエンド開発  >  PHP での 2 次元配列のソート手順

PHP での 2 次元配列のソート手順

WBOY
WBOYオリジナル
2016-06-13 13:04:38855ブラウズ

PHPにおける2次元配列のソート方法


/**
* @package??? BugFree
* @ バージョン???? $Id: FunctionsMain.inc.php,v 1.32 2005/09/24 11:38:37 wwccss Exp $
*
*
* レベル 2 の項目によって 2 次元配列を並べ替えるには、array_multisort() 関数を使用します。
*
* sysSortArray($Array , 「キー1」、「SORT_ASC」、「SORT_RETULAR」、「キー2」……)
* @著者?????????????????? Chunsheng Wang <wwccss@263.net>
* @param?配列?? $ArrayData??ソートする配列。
* @param?弦? $KeyName1???並べ替えの基準となる最初の項目。
* @param?弦? $SortOrder1?ソート順序("SORT_ASC"|"SORT_DESC")
* @param?弦? $SortType1??ソートタイプ("SORT_REGULAR"|"SORT_NUMERIC"|"SORT_STRING")
* @return array???????????????ソートされた配列。
*/
function sysSortArray($ArrayData,$KeyName1,$SortOrder1 = "SORT_ASC",$SortType1 = "SORT_REGULAR")
{
??? if(!is_array($ArrayData))
??? {
????????? return $ArrayData;
??? }
?
??? // 引数番号を取得します。
??? $ArgCount = func_num_args();
?
??? // 並べ替えの基準となるキーを取得し、SortRule 配列に置きます。
??? for($I = 1;$I
??? {
????????? $Arg = func_get_arg($I);
??????? if(!eregi("SORT",$Arg))
??????? {
????????????? $KeyNameList[] = $Arg;
???????????? $SortRule[]??? = '$'.$Arg;
??????? }
?????????他
????????? {
????????????? $SortRule[]??? = $Arg;
????????? }
??? }
?
??? // キーに従って値を取得し、配列に代入します。
??? foreach($ArrayData AS $Key => $Info)
??? {
????????? foreach($KeyNameList AS $KeyName)
??????? {
????????????? ${$KeyName}[$Key] = $Info[$KeyName];
??????? }
??? }
?
??? // eval 文字列を作成し、評価します。
??? $EvalString = 'array_multisort('.join(",",$SortRule).',$ArrayData);';
??? eval ($EvalString);
??? $ArrayData を返す;
}
?
?
//################## 例# # ############
$arr = array(
??? array(
?????? '名前' ??????? '勉強'、 ??? ??? =>??? '1235',
??????? 'タイプ'?????? ',
????????? '時間'????????? '1921-11-13'、
??? ???? 'クラス' ????? 'dd',
??? array(
????????? '名前'????????? =>??? '中国カンフー',
? ????? 'サイズ' ??????? '153',
??????? ?? =>??? 'jpe', ??????? '2005- 11-13 ',
??????? 'クラス'?????? =>??? ',
??? ,
??? array(
????????? '名前'????????? =>?? ? 'プログラミング' 、
??????? 'サイズ' ??????? =>??? ',
????? ?? 'タイプ' ??????? 'gif',
??????? '時間' ??? ??? '1997-11-13',
??????? 'クラス'????????? ??? )、
??? '名前' ?????? ? =>??? '中国カンフー',
??????? 'サイズ' ??????? '65' 🎜>
??????? 'タイプ'????????? 'jpe'、? '時間'?????? '1925-02-13',
?????? ;??? 'yy',
??? ),
??? ?? '名前' ????? =>??? '中国のカンフー'、
??????? >??? '5', ????? 'タイプ'????????? >
????????? '時間'????????? '1967-12-13'、
??? 'クラス'?????? =>??? 'rr',);
?
print_r($arr);
?
// 注: ソートすると、153 は 65 より小さくなります。数値的に
$temp = sysSortArray($arr,"name","SORT_ASC","type","SORT_DESC","size","SORT_ASC ","SORT_STRING");
?
print_r($temp);
?
?>
?
その他の関連する並べ替え関数:
?
sort ( array &$array [, int $sort_flags] )
この関数はターゲット配列をソートし、要素は低い値から高い値の順に配置されます。関数のパラメーターは参照によって渡され、ソートされた配列を返すのではなく、単に を返すことに注意してください。現在の配列の並べ替えでは、結果に関係なく値は返されません。
注: この関数は、配列内のセルに新しいキー名を割り当てます。これにより、並べ替えられるだけでなく、元のキー名が削除されます。
出力: (キーと値の関連付けが維持されなくなっていることがわかります)
asort ( array &$array [, int $sort_flags] )
この関数は配列をソートし、配列のインデックスはユニットに関連付けられたままになります。これは主に、ユニットの順序が重要な結合された配列をソートするために使用されます。また、参照によって渡され、 を返しません。値。
出力 (キーの値が変更されていないことがわかります):

Array ( [5] => 1 [1] => 2 [4] => 4 [0] => 5 [2] => 6 [3] => 8 )

rsort ( array &$array [, int $sort_flags] )

本函数类似sort函数, 对数组进行逆向排序(最高到最低)。

注:?本函数为?array?中的单元赋予新的键名。这将删除原有的键名而不仅是重新排序。

如果成功则返回?TRUE,失败则返回?FALSE

arsort ( array &$array [, int $sort_flags] )

本函数对数组进行逆向排序,数组的索引保持和单元的关联。主要用于对那些单元顺序很重要的结合数组进行排序。arsort()函数与asort()相同,只是它以相反的顺序(降序)对数组元素排序。

如果成功则返回?TRUE,失败则返回?FALSE

ksort ( array &$array [, int $sort_flags] )

ksort和sort的区别就是对数组按照键名排序而不是按值排序,保留键名到数据的关联.本函数主要用于关联数组. 如果成功则返回 TRUE,失败则返回 FALSE。

krsort ( array &$array [, int $sort_flags] )
见ksort,该函数同ksort只是把ksort后的结果逆序排序而已。

natsort ( array &$array )

本函数实现了一个和人们通常对字母数字字符串进行排序的方法一样的排序算法并保持原有键/值的关联,这被称为“自然排序”.本算法和通常的计算机字符串排序算法(用于 sort())的区别见下面示例.

如果成功则返回 TRUE,失败则返回 FALSE.
php手册中有个非常经典的例子

<?php $array1 = $array2 = array("img12.png", "img10.png", "img2.png", "img1.png"); sort($array1); echo "Standard sorting\n"; print_r($array1); natsort($array2); echo "\nNatural order sorting\n"; print_r($array2); ?>

上例将输出:Standard sorting

Array ( [0] => img1.png [1] => img10.png [2] => img12.png [3] => img2.png )

Natural order sorting

Array ( [3] => img1.png [2] => img2.png [1] => img10.png [0] => img12.png )

还有些数组排序函数以u(user)开头的, 都是些用户自定义排序函数。时间原因这就不多写了。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。