YouTubeのAPIを使えるようになるまでがめちゃくちゃわかりづらかったので、メモに残しておかないとやばいと思いました。

今回はPublicなデータにアクセスするための手順について書きます。OAuthについては触れません。

キーを取得しよう

まず、Google Developers Consoleへ行ってアプリケーションを作ってキーを取得する必要があります。

コンソールのCREATE PROJECTボタンを押して、名前を決めてプロジェクトを作ります。1回目は規約に同意するかどうかのチェックボックスがありますが、2回目いこうは省略されます。

そして、YouTube Data API v3をONにします。

次にAPIアクセスようのキーを発行します。

クライアント毎にアプリケーションキーを分けることができるようです。次の種類から選ぶことができます。ここではiOSを選んでみます。

  • Server key
  • Browser key
  • Android key
  • iOS key

こんな風にキーが発行されました。API keyという欄に書かれている文字列がキーです。APIで問い合わせる際にこのキーを使用します。

ビデオを取得する

ビデオ取得のやりかたをいくつかのパターンで試してみます。

リファレンスはこれ。Videos: list - YouTube — Google Developers

APIキーと検索キーワードを使って動画の検索ができます。

https://www.googleapis.com/youtube/v3/search?key={YOUR_API_KEY}&q={SEARCH_TERM}&part=id

例えばサッカーと検索したい場合はq=サッカーとしてリクエストを投げます。

 1// https://www.googleapis.com/youtube/v3/search?key={YOUR_API_KEY}&q=サッカー&part=id
 2
 3
 4// jsonレスポンス
 5{
 6 "kind": "youtube#searchListResponse",
 7 "etag": "\"qQvmwbutd8GSt4eS4lhnzoWBZs0/lGGCM9oSIhJS2gnOaQu1RjEiDx8\"",
 8 "nextPageToken": "CAUQAA",
 9 "pageInfo": {
10  "totalResults": 1000000,
11  "resultsPerPage": 5
12 },
13 "items": [
14  {
15   "kind": "youtube#searchResult",
16   "etag": "\"qQvmwbutd8GSt4eS4lhnzoWBZs0/RGl-lf1mZjCqGo-FbFwvgjAY6B0\"",
17   "id": {
18    "kind": "youtube#video",
19    "videoId": "lwYgdBQ0k3U"
20   }
21  },
22  {
23    // ...
24  }
25
26 ]
27} 

nextPageToken

デフォルトでは1ページあたり5件の結果が返ってきます。続きの結果を得たい場合には最初のレスポンスにあったnextPageTokenを使って次のようなリクエストをします。

https://www.googleapis.com/youtube/v3/search?key={YOUR_API_KEY}&q=サッカー&part=id&pageToken=CAUQAA

こうすると2ページ目の結果が得られた上、新たなnextPageTokenや前のページのためのprevPageTokenが得られるようになります。結果を次々に取ってきたい場合はこのtokenを使って繰り返しリクエストしていけばOK。

maxResults

1回のリクエストあたり5件だとまどろっこしい、100件ぐらい持ってこいと思った場合はmaxResultsパラメータを使います。

URLの最後に&maxResults=100に問い合わせてみると、、

 1{
 2 "error": {
 3  "errors": [
 4   {
 5    "domain": "global",
 6    "reason": "invalidParameter",
 7    "message": "Invalid value '100'. Values must be within the range: [0, 50]",
 8    "locationType": "parameter",
 9    "location": "maxResults"
10   }
11  ],
12  "code": 400,
13  "message": "Invalid value '100'. Values must be within the range: [0, 50]"
14 }
15} 

怒られた…。最大50件まででした。

part

part=idとなっているところを変えるとレスポンスで返ってくるパラメータを変えることができます。カンマ区切りで複数指定できます。

例えばpart=id,snippetとしてみると、、、

 1// https://www.googleapis.com/youtube/v3/search?key={YOUR_API_KEY}&q=サッカー&part=id,snippet
 2
 3
 4// レスポンス
 5{
 6 "kind": "youtube#searchListResponse",
 7 "etag": "\"qQvmwbutd8GSt4eS4lhnzoWBZs0/TvUA3aT9bg7gzx72UgdpWtsjAD0\"",
 8 "nextPageToken": "CAUQAA",
 9 "pageInfo": {
10  "totalResults": 1000000,
11  "resultsPerPage": 5
12 },
13 "items": [
14  {
15   "kind": "youtube#searchResult",
16   "etag": "\"qQvmwbutd8GSt4eS4lhnzoWBZs0/YNAKTLX6SbYCco99EQWCyVDIxCo\"",
17   "id": {
18    "kind": "youtube#video",
19    "videoId": "lwYgdBQ0k3U"
20   },
21   "snippet": {
22    "publishedAt": "2013-10-04T05:16:29.000Z",
23    "channelId": "UCZfWmiGEbwWNPMe2nr3WdDg",
24    "title": "【WOWOW】U-12ジュニアサッカーワールドチャレンジ2013 FCバルセロナ ダイジェスト",
25    "description": "U-12ジュニアサッカーワールドチャレンジ2013 FCバルセロナ ダイジェスト ☆U-12 Junior soccer world challenge 2013 FC Barcerona Infantil B digest 2013年8月27 ...",
26    "thumbnails": {
27     "default": {
28      "url": "https://i.ytimg.com/vi/lwYgdBQ0k3U/default.jpg"
29     },
30     "medium": {
31      "url": "https://i.ytimg.com/vi/lwYgdBQ0k3U/mqdefault.jpg"
32     },
33     "high": {
34      "url": "https://i.ytimg.com/vi/lwYgdBQ0k3U/hqdefault.jpg"
35     }
36    },
37    "channelTitle": "WOWOWofficial",
38    "liveBroadcastContent": "none"
39   }
40  },
41  {
42    // ...
43  }
44 ]
45} 

動画のタイトルやサムネイルのURLなど、詳細な情報を得られるようになりました。

もっといろいろな使い方ができるのですがここまでわかればあとはリファレンスを見てなんとかできるのでは。