В настоящее время я работаю над немецким сайтом, связанным с кино.
Поскольку я новичок в кодировании, я купил скрипт, который анализирует данные фильма из themoviedb.
Вот полный ответ JSON, который анализируется:
Небольшое исследование сценария показывает, что стандартная дата release_date анализируется:
public function getReleaseDate()
{
return (array_key_exists('release_date', $this->raw) ? $this->raw['release_date'] : $this->raw['first_air_date']);
}
Это прекрасно работает и дает мне «2017-04-25». Но внутри этого ответа JSON есть специфичные для региона даты выпуска, которые я хочу отфильтровать. Я специально хочу только «release_date» из этой части здесь:
{
certification: "",
iso_3166_1: "DE",
primary: false,
release_date: "2017-04-27"},
TL; DR: мне нужна функция, которая анализирует ответ JSON таким образом, что я получаю только «release_date» немецкого релиза («2017-04-27»).
Вот что я попробовал:
public function getReleaseDateLocalized()
{
$date = '';
if (isset($this->raw['releases']['countries']))
{
$dates = $this->raw['releases']['countries'];
}
elseif(isset($this->raw['release_date']))
{
return $this->raw['release_date'];
}
else
{
return '0000-00-00';
}
foreach($this->raw[$dates] as $locdates)
{
if (is_array($locdates))
{
$de .= array_search("DE", $locdates);
$date .= raw[$de]['release_date'];
}
else
{
$date .= $this->raw['release_date'];
}
}
return $date;
}
public function getReleaseDate()
{
$countries = $this->raw['releases']['countries'];
$de = array_search('DE', array_column($countries, 'iso_3166_1'));
return $countries[$de]['release_date'];
}
Других решений пока нет …