簡體   English   中英

PHP如何按不同數組中的鍵對數據進行排序

[英]php how to sort data by key in different array

我有一個數組$ data

[0] => Array
    {
        [configuration_id] => 5542abf530830
        [primary_language] => fr_MA       
    )

[1] => Array
    (
        [configuration_id] => 5542abf4c0721
        [primary_language] => en_IL
    )

[3] => Array
    (
        [configuration_id] => 5542abf3ec1f4
        [primary_language] => en_IL
    )

[4] => Array
    (
        [configuration_id] => 5542abf38933a
        [primary_language] => en_AE     
    )

[5] => Array
    (
        [configuration_id] => 5542abf2b5069 
        [primary_language] => uk_UA
    )

[6] => Array
    (
        [configuration_id] => 5542abf1df2c8
        [primary_language] => tr_TR
    )

[7] => Array
    (
        [configuration_id] => 5542abf114768
        [primary_language] => ru_RU
    )

[8] => Array
    (
        [configuration_id] => 5542abf03f401
        [primary_language] => pl_PL

    )

[9] => Array
    (
        [configuration_id] => 5542abef6be61
        [primary_language] => hu_HU
    )

[10] => Array
    (
        [configuration_id] => 5542abef080cb
        [primary_language] => hu_HU
    )

[11] => Array
    (
        [configuration_id] => 5542abee980a8
        [primary_language] => cs_CZ
    )


[12] => Array
    (
        [configuration_id] => 5542abedc5422
        [primary_language] => zh_TW
    )

[13] => Array
    (
        [configuration_id] => 5542abed60bad
        [primary_language] => zh_TW
    )

[14] => Array
    (
        [configuration_id] => 5542abecf12ac
        [primary_language] => zh_CN
    )

[15] => Array
    (
        [configuration_id] => 5542abec28ff1            
        [primary_language] => ko_KR
    }

[16] => Array
    (
        [configuration_id] => 5542abeb54eaf
        [primary_language] => sv_SE
    )

[17] => Array
    (
        [configuration_id] => 5542abe529770     
        [primary_language] => da_DK
    )

[18] => Array
    (
        [configuration_id] => 5542abe407af9
        [primary_language] => fr_FR
   }

[19] => Array
    (
        [configuration_id] => 5542abea828f7
        [primary_language] => pt_BR
    )

[20] => Array
    (
        [configuration_id] => 5542abdc37fb9
        [primary_language] => en_US
    )

此外,每種語言的其他數組屬於以下哪個層組,

$tier0_languages = array("en_US");
$tier1_languages = array("ja_JP", "de_DE", "fr_FR");
$tier2_languages = array("it_IT","es_ES","es_MX","nl_NL","pt_BR","da_DK","fi_FI","nb_NO","sv_SE");
$tier3_languages = array("ko_KR","zh_CN","zh_TW");
$tier4_languages = array("cs_CZ","ru_RU","tr_TR","pl_PL","hu_HU","uk_UA","fr_MA","en_AE","en_IL");

我想按每個語言組對$ data進行排序。 首先是$ tier0_language,然后是$ tier1_language,依此類推。 我該如何編寫php代碼來做到這一點? 請指教。

我首先將語言數組編譯成這樣的一組正則表達式

$expr1 = '('.implode('|', $tier0_languages).')'; 

所以最后你有這樣的事情

(en_US)|(ja_JP|de_DE|fr_FR)...

但如果所有語言都按順序排列,則使用匹配索引作為順序(使用PREG_OFFSET_CAPTURE)進行preg_match和uksort相對簡單。

您可以簡單地合並$tier(int)_languages uasort並使用uasort將其排序為

$tier0_languages = array("en_US");
$tier1_languages = array("ja_JP", "de_DE", "fr_FR");
$tier2_languages = array("it_IT","es_ES","es_MX","nl_NL","pt_BR","da_DK","fi_FI","nb_NO","sv_SE");
$tier3_languages = array("ko_KR","zh_CN","zh_TW");
$tier4_languages = array("cs_CZ","ru_RU","tr_TR","pl_PL","hu_HU","uk_UA","fr_MA","en_AE","en_IL");

$tier = array_merge($tier0_languages,$tier1_languages,$tier2_languages,$tier3_languages,$tier4_languages);

uasort($arr, function ($a,$b) use ($tier){
    foreach($tier as $value){
        if($value == $a['primary_language']){
            return 0;
            break;
        }
        if($value == $b['primary_language']){
            return 1;
            break;
        }
    }
});

print_r($arr);

工作小提琴

暫無
暫無

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

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