有两个阵列,两个长度相同且密钥相同:
$a1 = [1=>2000,65=>1354,103=>1787];
$a2 = [1=>'hello',65=>'hi',103=>'goodevening'];
asort($a1);
a1和a2的键是来自数据库的id。
a1按值排序。排序后,我们如何在a2中使用相同的排序顺序?
谢谢!
答案 0 :(得分:5)
我相信这有效:
$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);
答案 1 :(得分:1)
可能不是最佳..但它很短:
$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()
答案 2 :(得分:0)
如果可以处理丢失的ID关联(数组将被重新编入索引),您可能希望查看array_multisort()。
array_multisort($a1, $a2);
答案 3 :(得分:0)
foreach($a1 as $key => $value){
//do something with $a2
echo $a2[$key];
}