php教程 一維數組排序與多維數組排序
先看一維數據排序的實例asort()函數和ksort()函數
<?php
//asort()函數以數組的值升序為准
$mix = array("Clalei"=>10,"Bill"=>50,"Aala"=>100);
asort($mix);
print_r($mix);
//ksort()函數以數組的關鍵字升序為准
$mix = array("Clalei"=>100,"Bill"=>50,"Aala"=>10);
ksort($mix);
print_r($mix);
?>
一維數據排序二
sort()函數,可將數組按字母或是數字的升序(從低到高)來進行排序:
<?php
$name = array("Clalei","Bill","Aala");
sort($name);
for($i=0;$i<3;$i++){
echo $name[$i];
}
echo "<br />";
$price = array(100,50,10);
sort($price);
for($i=0;$i<3;$i++){
echo $price[$i]." | ";
}
?>
好了現在來看看二維數據庫教程排序實例代碼
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);
本例中將把 volume 降序排列,把 edition 升序排列。
現在有了包含有行的數組,但是 array_multisort() 需要一個包含列的數組,因此用以下代碼來取得列,然後排序。
// 取得列的列表
foreach ($data as $key => $row) {
$volume[$key] = $row['volume'];
$edition[$key] = $row['edition'];
}
// 將數據根據 volume 降序排列,根據 edition 升序排列
// 把 $data 作為最後一個參數,以通用鍵排序
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);
數據集合現在排好序了,結果如下:
volume | edition
-------+--------
98 | 2
86 | 1
86 | 6
85 | 6
67 | 2
67 | 7
二維數組排序三
array_multisort() 對二維數組進行排序
數組$roughData,我們打算按照accurancy排序。
Array( [0] => Array ( [username] => 10yl [accuracy] => 0.00 ) [1] => Array ( [username] => 11yl [accuracy] => 1.00 ) [2] => Array ( [username] => 12yl [accuracy] => 0.00 ) [3] => Array ( [username] => 13yl [accuracy] => 1.00 ))
方法:
(1)提取accuracy列數組
foreach ($roughData as $key => $row) {
$usernames[$key] = $row['username'];
$accuracy[$key] = $row['accuracy'];
}
(2)進行排序
array_multisort($accuracy, SORT_ASC,$roughData);
當print_r($roughData);後我們將得到一個按accuracy升序排序的二維數組
再來看個簡單實例用二維數組排序方法
<?php
$array[] = array("age"=>20,"name"=>"li");
$array[] = array("age"=>21,"name"=>"ai");
$array[] = array("age"=>20,"name"=>"ci");
$array[] = array("age"=>22,"name"=>"di");
foreach ($array as $key=>$value){
$age[$key] = $value['age'];
$name[$key] = $value['name'];
}
array_multisort($age,SORT_NUMERIC,SORT_DESC,$name,SORT_STRING,SORT_ASC,$array);
print_r($array);
?>