有两个数组,它们的长度相同,键也相同:
$a1 = [1=>2000,65=>1354,103=>1787];
$a2 = [1=>'hello',65=>'hi',103=>'goodevening'];
asort($a1);
a1和a2的键是来自数据库的id。
a1按值排序。排序后,我们如何在a2中使用相同的排序顺序呢?
谢谢!
$a1 = array(1=>2000,65=>1354,103=>1787);
$a2 = array(1=>'hello',65=>'hi',103=>'goodevening');
asort($a1); // sort $a1, maintaining array index
// sort $a2 by key, using the order of $a1
function my_uksort($a, $b) {
global $a1;
return $a1[$a] < $a1[$b] ? -1 : 1;
}
uksort($a2, 'my_uksort');
var_dump($a1);
var_dump($a2);
可能不是最优的,但很短:
$a1 = array(1=>2000,65=>1354,103=>1787);
$a2 = array(1=>'hello',65=>'hi',103=>'goodevening');
asort($a1);
foreach(array_keys($a1) as $i) $out[$i] = $a2[$i];
echo join("\n", $out);
也可以看一下uasort()函数
如果你能接受丢失 ID 关联(数组将被重新索引),那么你可能想看一下 array_multisort()。
array_multisort($a1, $a2);
foreach($a1 as $key => $value){
//do something with $a2
echo $a2[$key];
}