对具有索引的多维数组进行排序

时间:2012-03-26 17:00:11

标签: php arrays

我有一个类似的数组

Array
(
    [0] => Array
    (
        [UnitESN] => 14296
        [ScanNo] => 1
        [ScanDate] => Nov 21
        [ScanTime] => 10:15 AM
        [Qualifiers] => 
        [Notes] => 
        [BadgeData] => Array
            (
                [0] => HEATH---
                [1] => MCCU----
                [2] => HER---
                [3] => HCONNORS@------
                [4] => 
                [5] => 393
                [6] => 13350
                [7] => 
                [8] => 
                [9] => 111
            )

        [Signal] => +00/000
        [ConnectionDelay] => 0407
    )

     [1] => Array

等等...我想订购ASC或DESC ...让我们说在Col 8和Col 8是BadgeData中的第7号条目(8-1因为它从零开始),任何想法?我尝试过array_multisort但没有成功。

由于

2 个答案:

答案 0 :(得分:1)

感谢@Francois Deschenes带领我找到正确的答案。这是我发现的:

http://ca2.php.net/manual/en/function.uasort.php#104714

我编辑以满足我的需要。谢谢!

function SortArrayByCol(array $Array, $Key, $ASC=true, $Col=0) {
    $Result = array();

    $Values = array();
    foreach($Array as $ID => $Value){
        $Values[$ID] = isset($Value[$Key][$Col]) ? $Value[$Key][$Col] : null;
    }

    if($ASC){
        asort($Values);
    } else {
        arsort($Values);
    }

    foreach($Values as $Key => $Value) {
        $Result[$Key] = $Array[$Key];
    }

    return $Result;
}

答案 1 :(得分:1)

我很高兴你弄清楚了。这是我在被打断之前开始写作的内容。

基本uasort示例:

<?php

function cmp($a, $b) {
    if ($a['BadgeData'][7] == $b['BadgeData'][7]) {
        return 0;
    }
    // Ascending
    return ($a['BadgeData'][7] < $b['BadgeData'][7]) ? -1 : 1;
}

// Order the values of the array based on the value in BadgeData[7] in ascending order..
uasort($array, 'cmp');

看起来我可能误解了你的原始问题,但我认为你想按BadgeData[7]中的值对数组进行排序,但似乎你想为每个数组值排序BadgeData。