values - php sort array of array




按值排序多維數組 (5)

我怎樣才能排序這個數組的“訂單”鍵的值? 儘管這些值目前是連續的,但並不總是如此。

Array
(
    [0] => Array
        (
            [hashtag] => a7e87329b5eab8578f4f1098a152d6f4
            [title] => Flower
            [order] => 3
        )

    [1] => Array
        (
            [hashtag] => b24ce0cd392a5b0b8dedc66c25213594
            [title] => Free
            [order] => 2
        )

    [2] => Array
        (
            [hashtag] => e7d31fc0602fb2ede144d18cdffd816b
            [title] => Ready
            [order] => 1
        )
)

嘗試一個usort :如果你仍然使用PHP 5.2或更早的版本,你必須首先定義一個排序函數:

function sortByOrder($a, $b) {
    return $a['order'] - $b['order'];
}

usort($myArray, 'sortByOrder');

從PHP 5.3開始,您可以使用匿名函數:

usort($myArray, function($a, $b) {
    return $a['order'] - $b['order'];
});

最後在PHP 7中,您可以使用“飛船操作員”:

usort($myArray, function($a, $b) {
    return $a['order'] <=> $b['order'];
});

為了將其擴展到多維排序,如果第一個排序元素為零,請參考第二個/第三個排序元素 - 最好在下面進行說明。 您也可以使用它來對子元素進行排序。

usort($myArray, function($a, $b) {
    $retval = $a['order'] <=> $b['order'];
    if ($retval == 0) {
        $retval = $a['suborder'] <=> $b['suborder'];
        if ($retval == 0) {
            $retval = $a['details']['subsuborder'] <=> $b['details']['subsuborder'];
        }
    }
    return $retval;
});

如果您需要保留關鍵關聯,請使用uasort() - 請參閱手冊中數組排序功能的比較


我使用這個功能:

function array_sort_by_column(&$arr, $col, $dir = SORT_ASC) {
    $sort_col = array();
    foreach ($arr as $key=> $row) {
        $sort_col[$key] = $row[$col];
    }

    array_multisort($sort_col, $dir, $arr);
}


array_sort_by_column($array, 'order');

按“標題”鍵的值排序數組使用:

uasort($myArray, function($a, $b) {
    return strcmp($a['title'], $b['title']);
});

strcmp比較字符串。

uasort()維護定義的數組鍵。


讓我們面對現實:php沒有一個簡單的開箱即用功能來正確處理每個數組排序場景。

這個程序很直觀,這意味著更快的調試和維護:

// automatic population of array
$tempArray = array();
$annotations = array();
// ... some code
// SQL $sql retrieves result array $result 
// $row[0] is the ID, but is populated out of order (comes from 
// multiple selects populating various dimensions for the same DATE 
// for example
while($row = mysql_fetch_array($result)) {
    $needle = $row[0];
    arrayIndexes($needle);  // create a parallel array with IDs only
    $annotations[$needle]['someDimension'] = $row[1]; // whatever
}
asort($tempArray);
foreach ($tempArray as $arrayKey) {
    $dataInOrder = $annotations[$arrayKey]['someDimension']; 
    // .... more code
}

function arrayIndexes ($needle) {
    global $tempArray;
    if (!in_array($needle,$tempArray)) {
        array_push($tempArray,$needle);
    }
}

function aasort (&$array, $key) {
    $sorter=array();
    $ret=array();
    reset($array);
    foreach ($array as $ii => $va) {
        $sorter[$ii]=$va[$key];
    }
    asort($sorter);
    foreach ($sorter as $ii => $va) {
        $ret[$ii]=$array[$ii];
    }
    $array=$ret;
}

aasort($your_array,"order");




multidimensional-array