多维数组按键排序

时间:2013-06-14 15:57:24

标签: php arrays sorting

拥有这样的数组。

Array
(
    [0] => Array
        (
            [tipo] => Mn
            [tsk] => Vr
            [date] => 14-06
            [J] => 4
            [H] => 0
            [O] => 0
        )

[1] => Array
    (
        [tipo] => Ds
        [tsk] => Mv
        [date] => 14-06
        [J] => 0
        [H] => 0,5
        [O] => 0
    )

[2] => Array
    (
        [tipo] => Vr
        [tsk] => Do
        [date] => 14-06
        [J] => 0
        [H] => 0
        [O] => 5
    )

[3] => Array
    (
        [tipo] => Cl
        [tsk] => REG
        [date] => 14-06
        [J] => 0
        [H] => 4.25
        [O] => 0
    )

[4] => Array
    (
        [tipo] => Cl
        [tsk] => MB10
        [date] => 14-06
        [J] => 0
        [H] => 3.5
        [O] => 0
    )


)

我需要按J,H& amp; O键。我的意思是,我需要让所有的子数组首先在J上有值,然后是值为H的那些,然后是值为O的子数据。 注意:这些列彼此独占,因此如果一个值的值大于0,则其他两个列只能为0.

我尝试了很多东西,但显然这个看似简单的任务已经过去了。 我得到的最接近的是array_multisort,但我不能让它工作。我认为这样的事情应该有效:

foreach ($data as $key => $row) {
    $J[$key] = $row['J'];
    $H[$key] = $row['H'];
    $O[$key] = $row['O'];
}
array_multisort($J, SORT_ASC, $H, SORT_ASC, $O, SORT_ASC, $data);

但事实并非如此。

2 个答案:

答案 0 :(得分:2)

使用usort

 usort($data, function($a, $b){
         if (($a["J"] - $b["J"]) != 0) return $a["J"] - $b["J"];
         if (($a["H"] - $b["J"]) != 0) return $a["H"] - $b["H"];
         if (($a["O"] - $b["O"]) != 0) return $a["O"] - $b["O"];
         return 0;             
 });

<强>更新

只有当排序的值是数字时,上述方法才有效,我注意到数据不是这样,这应该适合你。

 usort($data, function($a, $b){
         if ($a["J"] > $b["J"]) return 1;
         if ($a["J"] < $b["J"]) return -1;
         if ($a["H"] > $b["H"]) return 1;
         if ($a["H"] < $b["H"]) return -1;
         if ($a["O"] > $b["O"]) return 1;
         if ($a["O"] < $b["O"]) return -1;
         return 0;             
 });

 ?>

答案 1 :(得分:1)

您必须将数组传递给array_multisort,而不是您正在做的事情:

尝试这样的事情:

foreach ($data as $key => $row) {
    $sortMe['J'][] = $row['J'];
    $sortMe['H'][] = $row['H'];
    $sortMe['O'][] = $row['O'];
}


array_multisort($sortMe['J'], SORT_DESC, SORT_NUMERIC,
                $sortMe['H'], SORT_ASC, SORT_REGULAR,
                $sortMe['O'], SORT_DESC, SORT_NUMERIC);

请注意,sortMe是字母'J','H','O'中的数组,因为我使用[]在foreach循环中添加项目,这就是你做错了。

希望这会对你有所帮助。