質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
87.20%
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

解決済

TypeError: Cannot read property '0' of undefined のエラーについて

suzu1916
suzu1916

総合スコア1

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

1回答

0リアクション

0クリップ

217閲覧

投稿2022/08/11 13:22

前提

スプレッドシートで複数人のYouTubeアカウントの登録者数などをリアルタイムで反映させたくて、ネットで見つけたコードを実際に使ってみたのですが、数年前の記事だったからかどうしてもエラーをはいてしまいます。

実現したいこと

・スプレッドシートの任意のシートにYouTubeアカウントの登録者数、チャンネル名、更新した日付を表示させる

発生している問題・エラーメッセージ

TypeError: Cannot read property '0' of undefined

該当のソースコード

ソースコード

function getSubscriberCount() {

//APIキー
var key = "ご自分のAPIキーを入力してください";
//反映させるシート 月ごとにシートを変えたい場合などに変更してください
var sheetName = "シート1"

var ss = SpreadsheetApp.getActiveSpreadsheet()
var srcSheet = ss.getSheetByName(sheetName);

var rowTitle = 1;
var rowURL = 2;
var rowEnd = srcSheet.getDataRange().getLastRow();
var rowToday = rowEnd + 1;
var colDate = 1;
var colStart = 2;
var colEnd = srcSheet.getDataRange().getLastColumn();

var formatDate = Utilities.formatDate(new Date(),"JST","yy/MM/dd");
srcSheet.getRange(rowToday,1).setValue(formatDate);

for (i=colStart; i<=colEnd; i++) {

var channelURL = srcSheet.getRange(rowURL,i).getValue();
var channelID = channelURL.slice(32);

//登録者数を取得
var dataURL = "https://www.googleapis.com/youtube/v3/channels?part=statistics&id=" + channelID +"&key=" + key;
var response = UrlFetchApp.fetch(dataURL)
var subscribe = JSON.parse(response.getContentText()).items[0].statistics.subscriberCount;

//チャンネルタイトルを取得
var dataURL = "https://www.googleapis.com/youtube/v3/channels?part=snippet&id=" + channelID +"&key=" + key ;
var response = UrlFetchApp.fetch(dataURL)
var channnelTitle = JSON.parse(response.getContentText()).items[0].snippet.title;

//登録者数をシートに挿入
srcSheet.getRange(rowToday,i).setValue(subscribe);

//チャンネルタイトルをシートに挿入
srcSheet.getRange(rowTitle,i).setValue(channnelTitle); 
}

};

function onOpen() {
var sheet = SpreadsheetApp.getActiveSpreadsheet();
var entries = [
{
name : "Youtubeチャンネル登録者数取得",
functionName : "getSubscriberCount"
}
];
sheet.addMenu("スクリプト実行", entries);
};

試したこと

TypeError: Cannot read property '0' of undefined
getSubscriberCount @ コード.gs:31

と表示されていたので、その部分を消してみたりしました。
その後もエラーの表示される部分をとりあえず消去してエラーはでなくなったものの、日付以外も何も出ないまま完了してしまいました。

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

https://note.com/nakashio_note/n/n28c1979224a1
参考にしたのはこの記事で、2019年のものなので色々変わっているのかもしれないと思いましたが、何をどう変更すればよいのかわからず困っております。

以下のような質問にはリアクションをつけましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

リアクションが多い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

jimbe

2022/08/11 17:06

ご提示のコードは java ではありません。適切な言語のタグを付けて頂かないと、その言語が出来る人に質問を見て頂けない可能性が上がってしまいます。
suzu1916

2022/08/15 08:32

回答ありがとうございます! 勝手にJavaかと思い込んでおりました、修正致しますありがとうございます!

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。