упорядочить php ассоциативный вложенный массив по ключу даты

#php #arrays #usort #array-multisort

#php #массивы #usort #массив-мультисортировка

Вопрос:

Я хочу упорядочить даты внутри каждого [dataPartenza] этого ассоциативного массива в порядке возрастания, я нашел много ответов об индексированных массивах, но не что-то подобное. проблема здесь в том, что даты — это не значение массива, а сами ключи, поэтому я не могу применить методы usort, которые я нашел надругие ответы.

PHP:

 [destinazione] => Array(
[Corfù] => Array(
  [dataPartenza] => Array(
    [2021 - 07 - 16] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 365.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 50.00
          )
        )[comfort] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 395.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 60.00
          )
        )
      )
    )[2021 - 07 - 23] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 365.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 50.00
          )
        )[comfort] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 395.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 60.00
          )
        )
      )
    )[2021 - 08 - 06] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 365.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => N / S[prezzo] => 50.00
          )
        )[comfort] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 385.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 60.00
          )
        )
      )
    )
  )
)[Zante] => Array(
  [dataPartenza] => Array(
    [2021 - 07 - 17] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => 5[prezzo] => 395.00
          )[01 | bilocale] => Array(
            [capienza] => 4[prezzo] => 415.00
          )[02 | studios] => Array(
            [capienza] => 3[prezzo] => 405.00
          )[03 | studios] => Array(
            [capienza] => 2[prezzo] => 425.00
          )
        )
      )
    )[2021 - 07 - 24] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 395.00
          )[01 | bilocale] => Array(
            [capienza] => 4[prezzo] => 425.00
          )[02 | studio] => Array(
            [capienza] => 3[prezzo] => 415.00
          )[03 | studio] => Array(
            [capienza] => 2[prezzo] => 445.00
          )
        )
      )
    )[2021 - 07 - 31] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 395.00
          )[01 | bilocale] => Array(
            [capienza] => 4[prezzo] => 425.00
          )[02 | studio] => Array(
            [capienza] => 3[prezzo] => 415.00
          )[03 | studio] => Array(
            [capienza] => 3[prezzo] => 445.00
          )
        )
      )
    )
  )
)[Pag] => Array(
  [dataPartenza] => Array(
    [2021 - 07 - 18] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 274.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 3[prezzo] => 30.00
          )[02 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 50.00
          )
        )
      )
    )[2021 - 07 - 25] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 274.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 3[prezzo] => 30.00
          )[02 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 50.00
          )
        )
      )
    )[2021 - 08 - 01] => Array(
      [soldout] => [sistemazione] => Array(
        [basic] => Array(
          [00 | quota base] => Array(
            [capienza] => N / S[prezzo] => 274.00
          )[01 | supplemento monolocale] => Array(
            [capienza] => 3[prezzo] => 30.00
          )[02 | supplemento monolocale] => Array(
            [capienza] => 2[prezzo] => 50.00
          )
        )
      )
    )
  )
)
))
  

как и было предложено, я добавляю версию json_encode, более компактную

JSON:

     {
       "destinazione":{
          "Corfù":{
             "dataPartenza":{
                "2021-07-16":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"365.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"50.00"
                         }
                      },
                      "comfort":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"395.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"60.00"
                         }
                      }
                   }
                },
                "2021-07-23":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"365.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"50.00"
                         }
                      },
                      "comfort":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"395.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"60.00"
                         }
                      }
                   }
                },
                "2021-08-06":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"365.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"N/S",
                            "prezzo":"50.00"
                         }
                      },
                      "comfort":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"385.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"60.00"
                         }
                      }
                   }
                }
             }
          },
          "Zante":{
             "dataPartenza":{
                "2021-07-17":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"5",
                            "prezzo":"395.00"
                         },
                         "01|bilocale":{
                            "capienza":"4",
                            "prezzo":"415.00"
                         },
                         "02|studios":{
                            "capienza":"3",
                            "prezzo":"405.00"
                         },
                         "03|studios":{
                            "capienza":"2",
                            "prezzo":"425.00"
                         }
                      }
                   }
                },
                "2021-07-24":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"395.00"
                         },
                         "01|bilocale ":{
                            "capienza":"4",
                            "prezzo":"425.00"
                         },
                         "02|studio":{
                            "capienza":"3",
                            "prezzo":"415.00"
                         },
                         "03|studio":{
                            "capienza":"2",
                            "prezzo":"445.00"
                         }
                      }
                   }
                },
                "2021-07-31":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"395.00"
                         },
                         "01|bilocale":{
                            "capienza":"4",
                            "prezzo":"425.00"
                         },
                         "02|studio":{
                            "capienza":"3",
                            "prezzo":"415.00"
                         },
                         "03|studio":{
                            "capienza":"3",
                            "prezzo":"445.00"
                         }
                      }
                   }
                }
             }
          },
          "Pag":{
             "dataPartenza":{
                "2021-07-18":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"274.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"3",
                            "prezzo":"30.00"
                         },
                         "02|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"50.00"
                         }
                      }
                   }
                },
                "2021-07-25":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"274.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"3",
                            "prezzo":"30.00"
                         },
                         "02|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"50.00"
                         }
                      }
                   }
                },
                "2021-08-01":{
                   "soldout":false,
                   "sistemazione":{
                      "basic":{
                         "00|quota base":{
                            "capienza":"N/S",
                            "prezzo":"274.00"
                         },
                         "01|supplemento monolocale":{
                            "capienza":"3",
                            "prezzo":"30.00"
                         },
                         "02|supplemento monolocale":{
                            "capienza":"2",
                            "prezzo":"50.00"
                         }
                      }
                   }
                }
             }
          }
       }
    }

I'm putting here the snippet for the solution provided by @Anton this is working perfectly with usort and regular sort flag for yyyy-mm-dd formatted value:

**PHP:**
```php
<?php
    $data = '{"destinazione":{"Corfù":{"dataPartenza":{"2021-07-24":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"N/S","prezzo":"365.00"},"01|supplemento monolocale":{"capienza":"2","prezzo":"50.00"}},"comfort":{"00|quota base":{"capienza":"N/S","prezzo":"395.00"},"01|supplemento monolocale":{"capienza":"2","prezzo":"60.00"}}}},"2021-07-23":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"N/S","prezzo":"365.00"},"01|supplemento monolocale":{"capienza":"2","prezzo":"50.00"}},"comfort":{"00|quota base":{"capienza":"N/S","prezzo":"395.00"},"01|supplemento monolocale":{"capienza":"2","prezzo":"60.00"}}}},"2021-01-06":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"N/S","prezzo":"365.00"},"01|supplemento monolocale":{"capienza":"N/S","prezzo":"50.00"}},"comfort":{"00|quota base":{"capienza":"N/S","prezzo":"385.00"},"01|supplemento monolocale":{"capienza":"2","prezzo":"60.00"}}}}}},"Zante":{"dataPartenza":{"2021-07-17":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"5","prezzo":"395.00"},"01|bilocale":{"capienza":"4","prezzo":"415.00"},"02|studios":{"capienza":"3","prezzo":"405.00"},"03|studios":{"capienza":"2","prezzo":"425.00"}}}},"2021-07-24":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"N/S","prezzo":"395.00"},"01|bilocale ":{"capienza":"4","prezzo":"425.00"},"02|studio":{"capienza":"3","prezzo":"415.00"},"03|studio":{"capienza":"2","prezzo":"445.00"}}}},"2021-07-31":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"N/S","prezzo":"395.00"},"01|bilocale":{"capienza":"4","prezzo":"425.00"},"02|studio":{"capienza":"3","prezzo":"415.00"},"03|studio":{"capienza":"3","prezzo":"445.00"}}}}}},"Pag":{"dataPartenza":{"2021-07-18":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"N/S","prezzo":"274.00"},"01|supplemento monolocale":{"capienza":"3","prezzo":"30.00"},"02|supplemento monolocale":{"capienza":"2","prezzo":"50.00"}}}},"2021-08-01":{"soldout":false,"sistemazione":{"basic":{"00|quota base":{"capienza":"N/S","prezzo":"274.00"},"01|supplemento monolocale":{"capienza":"3","prezzo":"30.00"},"02|supplemento monolocale":{"capienza":"2","prezzo":"50.00"}}}}}}}}';
    $input = json_decode($data, true);
    
    $output = $input;
    foreach ($input['destinazione'] as $city_name => $city_data) {
        $dataPartenza = $city_data['dataPartenza'];
        ksort($dataPartenza);
        $output['destinazione'][$city_name]['dataPartenza'] = $dataPartenza;
    }
    
    echo "nnOUTPUT: " . json_encode($output);
  

РЕДАКТИРОВАТЬ: очищенный массив в более удобочитаемом формате и добавлена версия json

Комментарии:

1. ksort ?

2. Массив в вашем примере нечитаем. Используйте json_encode , например, чтобы сделать его более компактным

3. @Anton Я тоже добавил версию json

4. @silvered.dragon Хорошо, теперь мы видим, что ваши даты уже отсортированы по возрастанию. Зачем вам нужно сортировать их еще раз?

5. @Anton этот json поступает из динамической расширяемой формы, которая может расти со временем. Итак, теперь они упорядочены, потому что я только что сам заполнил форму этим способом asc. Если я добавлю больше дат, я хочу, чтобы они были в порядке возрастания.

Ответ №1:

Ответ уже есть в комментариях: ksort . Вот пример: нажмите.

Итак, я беру массив, сортирую его, возвращаю к результату:

 // get 'dataPartenza'
$dataPartenza = $city_data['dataPartenza'];
// sort it
ksort($dataPartenza);
// put to result
$output['destinazione'][$city_name]['dataPartenza'] = $dataPartenza;