PHP массив сортировки с произвольным порядком - PullRequest
1 голос
/ 29 мая 2020

Я знаю, что этот вопрос не новый, но решения не нашел. У меня есть запрос API, который возвращает JSON:

$values = '{"retcode" : "0 Done", 
            "trans_id" : "326678", 
            "answer" : [ { "City" : "New York", "Digits" : "5", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203568", "Value" : "0.66480", "Average" : "0.66485", "Last" : "0.00000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Berlin","Digits" : "5", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203568", "Value" : "0.89917", "Average" : "0.89920", "Last" : "0.00000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Paris", "Digits" : "3", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203569", "Value" : "119.680", "Average" : "119.684", "Last" : "0.000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Athens", "Digits" : "5", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203569", "Value" : "1.11211", "Average" : "1.11213", "Last" : "0.00000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Beijing", "Digits" : "5", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203568", "Value" : "1.23677", "Average" : "1.23686", "Last" : "0.00000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Moscow", "Digits" : "5", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203167", "Value" : "1.37647", "Average" : "1.37654", "Last" : "0.00000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Tokyo", "Digits" : "3", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203370", "Value" : "107.616", "Average" : "107.619", "Last" : "0.000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Melbourne", "Digits" : "2", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203569", "Value" : "11622.15", "Average" : "11622.95", "Last" : "0.00", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Amman", "Digits" : "2", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203370", "Value" : "3017.30", "Average" : "3017.70", "Last" : "0.00", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Chicago", "Digits" : "2", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203569", "Value" : "25261.20", "Average" : "25262.70", "Last" : "0.00", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Los Angeles", "Digits" : "2", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203772", "Value" : "9408.10", "Average" : "9409.00", "Last" : "0.00", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Madrid", "Digits" : "3", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203772", "Value" : "33.623", "Average" : "33.663", "Last" : "0.000", "Volume" : "0", "VolumeReal" : "0" 
                    } , { "City" : "Rome", "Digits" : "2", "Datetime" : "1590773203", "DatetimeMsc" : "1590773203370", "Value" : "1731.83", "Average" : "1732.06", "Last" : "0.00", "Volume" : "0", "VolumeReal" : "0" 
                    } ] }';

Я конвертирую JSON в массив и создаю также массив с настраиваемым порядком, зависящим от города

$values=json_decode($values, true);
$order = array('Rome', 'Berlin', 'Tokyo','Beijing',
                'New York','Athens','Moscow','Los Angeles',
                'Paris','Madrid','Chicago','Melbourne','Amman');                
usort($values, function ($a, $b) use ($order) {
    $pos_a = array_search($a['City'], $order);
    $pos_b = array_search($b['City'], $order);
    return $pos_a - $pos_b;
});
var_dump($values);

Этот код возвращает тот же массив, что и после json_decode. Какие-либо предложения? Заранее спасибо.

1 Ответ

0 голосов
/ 29 мая 2020

Просто замените массив $ values ​​на $ values ​​['answer'] в функции usort

$values=json_decode($values, true);
$order = array('Rome', 'Berlin', 'Tokyo','Beijing',
                'New York','Athens','Moscow','Los Angeles',
                'Paris','Madrid','Chicago','Melbourne','Amman');    
usort($values['answer'], function ($a, $b) use ($order) {
    $pos_a = array_search($a['City'], $order);
    $pos_b = array_search($b['City'], $order);
    return $pos_a - $pos_b;
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...