簡體   English   中英

php array_multisort()通過2個字段

[英]php array_multisort() by 2 field

我使用array_multisort()函數按字段值對數組進行排序。 我需要按日期和時間按2個字段值對其進行排序。 這是數組的結構:

Array
(
    [0] => Array
        (
            [id_art] => 5292
            [free_art] => 0
            [apero_art] => 0
            [name_cat] => Teatro
            [date_dat] => 2010-11-24
            [date2_dat] => 0000-00-00
            [name_spa] => Cinema Teatro
            [title_int] => Il piacere dell'onestà 
            [id_cat] => 2
            [time_tim] => 20:30:00
            [intro_int] => Una produzione Teatro Eliseo di Roma - ChiassoCultura 
            [image_art] => noimage.png
        )

    [1] => Array
        (
            [id_art] => 4983
            [free_art] => 0
            [apero_art] => 0
            [name_cat] => Cinema
            [date_dat] => 2011-04-20
            [date2_dat] => 2011-04-20
            [name_spa] => Cinema Morettina
            [title_int] => Inland Empire
            [id_cat] => 1
            [time_tim] => 20:30:00
            [intro_int] => Rassegna dedicata a David Lynch
            [image_art] => noimage.png
        )

    [2] => Array
        (
            [id_art] => 4983
            [free_art] => 0
            [apero_art] => 0
            [name_cat] => Cinema
            [date_dat] => 2011-04-22
            [date2_dat] => 2011-04-22
            [name_spa] => Cinema Iride
            [title_int] => Inland Empire
            [id_cat] => 1
            [time_tim] => 17:00:00
            [intro_int] => Rassegna dedicata a David Lynch
            [image_art] => noimage.png
        )....

我現在要做的是:

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); 
}

如何一次輕松實現雙重排序?

謝謝。

如果我了解您需要做什么,可以使用usort:

usort($array, function($a, $b) {
    if ($a['date_cat'] > $b['date_cat']) return 1;
    if ($a['date_cat'] < $b['date_cat']) return -1;
    if ($a['time_tim'] > $b['time_tim']) return 1;
    if ($a['time_tim'] < $b['time_tim']) return -1;        
    return 0;
});

對我來說,您的功能運作方式有些曲折。 您提取數組的一列以創建要排序的數組,該數組鏈接到原始數組。 花了幾讀和一次php手動檢查才能理解您的代碼(太糟糕了),(對我而言)您應該(在我看來)在調用排序之前將索引數組的創建分離到另一個函數中。

如果需要動態選擇列,則可以利用閉包(PHP 5.3+?):

function your_sort($orderby, $array) {
    return usort($array, function ($a, $b) use ($orderby) {
        foreach($orderby as $field) {
            if ($a[$field] > $b[$field]) return 1;
            if ($a[$field] < $b[$field]) return -1;
        }
        return 0;
    });
}

然后您可以像下面這樣調用函數:

your_sort(array('date_cat','time_tim'), $array);

從php.net注釋和其他調整中獲得一些代碼,我編寫了一個接受以下參數的函數:

  1. $ a =數組
  2. $ orderby =用sql語言編寫的訂單字符串
  3. $ children_key =保存最終子節點的最終列的名稱

這里的功能:

function array_multiorderby( $data, $orderby, $children_key=false )
{
    // parsing orderby
    $args = array();
    $x = explode( ' ', str_replace( ',', ' ', $orderby ) );
    foreach( $x as $item ) 
    {
        $item = trim( $item );
        if( $item=='' ) continue;
        if( strtolower($item)=='asc' ) $item = SORT_ASC;
        else if( strtolower($item)=='desc' ) $item = SORT_DESC;
        $args[] = $item;
    }

    // order
    foreach ($args as $n => $field) 
    {
        if (is_string($field)) 
        {
            $tmp = array();
            foreach ($data as $key => $row)
            $tmp[$key] = $row[$field];
            $args[$n] = $tmp;
        }
    }
    $args[] = &$data;
    call_user_func_array('array_multisort', $args);
    $data = array_pop($args);

    // order children
    if( $children_key )
    {
        foreach( $data as $k=>$v ) if( is_array($v[$children_key]) ) $data[$k][$children_key] = array_multiorderby( $v[$children_key], $children_key, $orderby );
    }

    // return
    return $data;
}

適用於您的特定情況:

$array = array_multiorderby( $array, "date_dat DESC, time_tim DESC" );

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM