-1

我目前正在开发一个与德国电影相关的网站。由于我是编码新手,所以我购买了一个从 themoviedb 解析电影数据的脚本。

这是正在解析的完整 JSON 响应:

https://api.themoviedb.org/3/movie/283995?api_key=9ff892d334d361aac74e06ac0e1acb96&append_to_response=releases

对脚本的一点研究表明,标准的 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;
}
4

1 回答 1

1
public function getReleaseDate()
{
  $countries = $this->raw['releases']['countries'];
  $de = array_search('DE', array_column($countries, 'iso_3166_1'));

  return $countries[$de]['release_date'];
}
于 2017-02-28T00:28:34.233 回答