1

我有以下数组:

$data['array'] = array(
    1 => array(
        'currency_name' => 'USD',
        'totals' => '310.00 USD'
    ),
    24 => array(
        'currency_name' => 'EUR',
        'totals' => '200.00 EUR'
    ),
    26 => array(
        'currency_name' => 'GBP',
        'totals' => '100.00 GBP'
    )
);

我想currency_name按键排序,我使用了以下功能:

// sort the array by currency_name key
$sort = array();
foreach ($data['array'] as $i => $row)
{
    $sort[$i] = $row['currency_name'];
}
array_multisort($sort, SORT_NATURAL, $data['array']);

输出:

Array
(
    [array] => Array
        (
            [0] => Array
                (
                    [currency_name] => EUR
                    [totals] => 200.00 EUR
                )

            [1] => Array
                (
                    [currency_name] => GBP
                    [totals] => 100.00 GBP
                )

            [2] => Array
                (
                    [currency_name] => USD
                    [totals] => 310.00 USD
                )

        )

)

预期的:

Array
(
    [array] => Array
        (
            [24] => Array
                (
                    [currency_name] => EUR
                    [totals] => 200.00 EUR
                )

            [26] => Array
                (
                    [currency_name] => GBP
                    [totals] => 100.00 GBP
                )

            [1] => Array
                (
                    [currency_name] => USD
                    [totals] => 310.00 USD
                )

        )

)

这是重新索引数组,我不想要。我以后需要这些钥匙。

注意:
* 我上面使用的方法是这个
* 我需要SORT_NATURAL这个函数,因为我也将这个函数用于其他字符串。

4

2 回答 2

7

正如您从array_multisort文档中看到的那样,仅保留关联(字符串)键。你可以uasort改用。

uasort($data['array'], function($a, $b) {
    return strnatcmp($a['currency_name'], $b['currency_name']);
});
于 2013-09-27T07:37:50.187 回答
1

你可以试试natcasesort($array)函数。此函数使用不区分大小写的“自然顺序”算法对数组进行排序。成功时返回 TRUE,失败时返回 FALSE。

于 2013-09-27T07:45:23.083 回答