🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

YouTube API

YouTube APIはYouTubeのビデオコンテンツと機能性をウェブサイト、アプリケーション、デバイスに統合することを可能にします。

Q&A

解決済

1回答

2156閲覧

PlaylistItemsから取得したvideoIdでvideosからitem.snippetを取得したい

Nat-_-tun

総合スコア1

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

YouTube API

YouTube APIはYouTubeのビデオコンテンツと機能性をウェブサイト、アプリケーション、デバイスに統合することを可能にします。

0グッド

0クリップ

投稿2020/11/28 03:27

編集2020/11/29 03:49

こちらのサイトを参考に書き換えてみたのですが、以下のコードではプレイリストを作成したチャンネルのchannelIdが取得されます。
動画を投稿したチャンネルのchannelIdを取得するには、どうしたら良いのでしょうか。

よろしくお願いいたします。

実現したいこと

  1. playlistIdを基にPlaylistItemsからvideoIdを取得
  2. videoIdを基にvideosからtitleやchannelId等を取得
  3. 重複していないデータをシートの最後行に書き込む

発生している問題

PlaylistItemsから取得出来るchannelIdは、プレイリストを作成したチャンネルのもの。
動画を投稿したチャンネルのchannelIdが欲しい。

該当のソースコード

GAS

1function getPlaylistItems(){ 2 const playlistId = "{取得したいプレイリストID}"; 3 const maxResults = 100; 4 const dstSsName = "{書き込みたいスプレッドシート名}"; 5 6 // プレイリストのデータを取得する 7 let playlistData = []; 8 let nextPageToken = ""; 9 let remainingResults = maxResults; 10 11 while (nextPageToken != null && remainingResults > 0){ 12 const playlistResponse = YouTube.PlaylistItems.list("snippet", { 13 playlistId: playlistId, 14 maxResults: remainingResults, 15 pageToken: nextPageToken 16 }); 17 18 const itemsNum = playlistResponse.items.length; 19 for (let i = 0; i < itemsNum; i++){ 20 const item = playlistResponse.items[i]; 21 const video_publish = item.snippet.publishedAt.replace(/T\d\d:\d\d:\d\dZ/g,""); 22 const channel_id = item.snippet.channelId; 23 const video_id = item.snippet.resourceId.videoId; 24 const video_title = item.snippet.title; 25 const video_description = item.snippet.description.replace(/\r?\n/g,""); 26 const channel_title = item.snippet.channelTitle; 27 28 playlistData.push([video_publish, video_id, video_title, video_description, channel_id, channel_title]); 29 } 30 31 nextPageToken = playlistResponse.nextPageToken; 32 remainingResults -= itemsNum; 33 } 34 35 // 取得したデータをシートに書き込む 36 const dstSs = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(dstSsName); 37 const dstSsLstRow = dstSs.getLastRow()+1; 38 dstSs.getRange(dstSsLstRow, 2, playlistData.length, playlistData[0].length).setValues(playlistData); 39}

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

YouTube API
Google Apps Script

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

基本的にはcontentDetails.videoIdのリストを作成し、YouTube.Videos.listを用いて取得します。

以下ご参考まで。

js

1function getPlaylistItems(){ 2 const playlistId = '{取得したいプレイリストID}'; 3 const maxResults = 50; 4 const dstSsName = '{書き込みたいスプレッドシート名}'; 5 6 // プレイリストのデータを取得する 7 const playlistData = []; 8 const playlistVideoIds = []; 9 let nextPageToken = ''; 10 11 while (nextPageToken != null){ 12 const playlistResponse = YouTube.PlaylistItems.list(['contentDetails'], { 13 playlistId: playlistId, 14 maxResults: maxResults, 15 pageToken: nextPageToken 16 }); 17 18 playlistVideoIds.push(...playlistResponse.items.map(item => item.contentDetails.videoId)); 19 20 nextPageToken = playlistResponse.nextPageToken; 21 } 22 23 nextPageToken = ''; 24 25 while (nextPageToken != null){ 26 const videosResponse = YouTube.Videos.list(['id', 'snippet'], { 27 id: playlistVideoIds, 28 maxResults: maxResults, 29 pageToken: nextPageToken 30 }); 31 32 playlistData.push(...videosResponse.items.map(item => [ 33 item.snippet.publishedAt.replace(/T\d\d:\d\d:\d\dZ/g,""), 34 item.id, 35 item.snippet.title, 36 item.snippet.description, 37 item.snippet.channelId, 38 item.snippet.channelTitle 39 ])); 40 41 nextPageToken = videosResponse.nextPageToken; 42 } 43 44 // 取得したデータをシートに書き込む 45 const dstSs = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(dstSsName); 46 const dstSsLstRow = dstSs.getLastRow() + 1; 47 dstSs.getRange(dstSsLstRow, 2, playlistData.length, playlistData[0].length).setValues(playlistData); 48}

投稿2020/12/17 00:28

macaron_xxx

総合スコア3191

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Nat-_-tun

2020/12/20 08:03

> macaron_xxx さん ご回答ありがとうございます! 教えて頂けたコードで無事に動画を投稿したチャンネルのIdを取得する事が出来ました。 プログラミングに詳しい人が周りにいないのでとても助かりました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問