我有2个数组,第一个包含对象的值,第二个包含它们的ID。
以这种形式:
$values[0] applies to $ids[0]
$values[1] applies to $ids[1]
我需要从最低到最高(值是整数)对第一个数组(使用 sort() )进行排序 - 这不是问题。问题是,当我用值对数组进行排序时,我将丢失该值的 ID。
我的问题是:如何做到这一点
If $values[0] turns to $values[5], automatically turn $ids[0] to $ids[5]
谢谢
更新:
$values和$ids的内容:
$values[0] = 1.5;
$values[1] = 2.4;
$values[2] = 15.7;
$values[3] = 11.7;
$values[4] = 4.8;
$values[5] = 0.4;
$ids[0] = 1;
$ids[1] = 2;
$ids[2] = 3;
$ids[3] = 4;
$ids[4] = 5;
$ids[5] = 6;
首先组合数组,然后按键排序:
$newArr = array_combine($ids, $values);
ksort($newArr);
听起来
你正在寻找array_combine()
:
例
<?php
$ids = array(2, 1, 3); // IDs
$values = array(a, b, c); // Values
$array = array_combine($ids, $values); // Combine arrays as ID => Value
ksort($arrays); // Sort new array
print_r($array); // Echo array
输出
Array
(
1 => b,
2 => a,
3 => c,
)
按照下面的代码...还没有测试过...但它必须起作用。易于理解..
<?php
$count = count($values);
for($i = 0; $i<$count; $i++)
{
if($i == 0)
{
$sort1 = $values[$i];
$sort2 = $ids[$i];
$temp = 0;
}
if($sort1 > $values[$i])
{
$sort1 = $values[$i];
$sort2 = $ids[$i];
$temp_val = $values[$temp];
$temp_id = $ids[$temp];
$values['temp'] = $values[$i];
$ids['temp'] = $ids[$i];
$temp = $i;
$values[$i] = $temp_val;
$ids[$i] = $temp_id;
}
}
?>