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

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

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

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

Google Apps Script

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Twitter

Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

Q&A

0回答

542閲覧

GASでツイートの検索結果からurlのみを取り出してGoogleスプレッドシートへ出力したい

pepe4422

総合スコア5

Google スプレッドシート

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

Google Apps Script

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Twitter

Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

0グッド

1クリップ

投稿2020/09/23 16:22

#前提・実現したいこと
Google Apps ScriptでTwitterを検索を行い、
上位検索結果5件のツイートURLをスプレッドシートへ出力したいです。
類似の質問と思われる下記について参照の上、試行錯誤しているのですがうまくいかず、お力をお借りしたく。。。

・類似と思われる質問
https://teratail.com/questions/234557
(取得したい情報が異なる。類似例はtext、本質問の対象はurl)

tweet投稿はできておりますので、認証は問題ないかと考えております。

#発生している問題・エラーメッセージ
以下のメッセージが出力される。

"TypeError: Cannot read property 'urls' of undefined"

#ソースコード

function twitterSearch(){ var twitterService = getService(); var sheet = SpreadsheetApp.getActive().getSheetByName('AAA'); var json = twitterService.fetch("https://api.twitter.com/1.1/search/tweets.json?q=横浜FC"); var array = JSON.parse(json); sheet.getRange('B1').setValue(array.statuses.entities.urls.url); Logger.log(array); }

#試したこと
上記であげた類似例同様、ログ上は取得できているように見えますので、ここからurlのみを取り出そうと試みました。

Twitter Deveroper Search Tweets APIガイドページに記載の内容から、取得したいURLは以下の位置にあるように見えるのですが、
array.statuses.entities
array.statuses.entities.urls
array.statuses.entities.urls.url
など、arrayでいろいろ試してみてもうまく取得することができませんでした。
そもそも、上記のような指定方法がおかしいのでしょうか?

・Twitter Deveroper Search Tweets APIガイドページ
https://developer.twitter.com/en/docs/twitter-api/v1/tweets/search/api-reference/get-search-tweets

また、以下、一部となりますが出力されたログです。
"[20-09-24 01:01:00:704 JST] ログ出力のサイズが大きすぎます。出力を切捨てます。 {statuses=[{in_reply_to_user_id_str=null, in_reply_to_user_id=null, metadata={iso_language_code=ja, result_type=recent}, retweeted=false, retweeted_status={retweet_count=1646.0, coordinates=null, user={profile_banner_url=https://pbs.twimg.com/profile_banners/725265957866901505/1598312790, profile_sidebar_fill_color=000000, is_translator=false, notifications=false, description=ライブスポーツが一番観られるのは #DAZN????
⚽⚾????????????????????????⛳????????

Instagram▶️https://t.co/muoKqF900L
YouTube▶️https://t.co/U83Y8KVOJX
Facebook▶️https://t.co/qzfbkq5UFF, default_profile=false, id=7.252659578669015E17, profile_image_url_https=https://pbs.twimg.com/profile_images/1054021278405877760/ptFsV8Gp_normal.jpg, created_at=Wed Apr 27 10:10:53 +0000 2016, profile_use_background_image=false, default_profile_image=false, entities={description={urls=[{url=https://t.co/muoKqF900L, expanded_url=http://bit.ly/2GxCW8G, indices=[48.0, 71.0], display_url=bit.ly/2GxCW8G}, {expanded_url=http://goo.gl/VSLeyB, indices=[81.0, 104.0], url=https://t.co/U83Y8KVOJX, display_url=goo.gl/VSLeyB}, {expanded_url=http://bit.ly/2Cmz35l, indices=[115.0, 138.0], display_url=bit.ly/2Cmz35l, url=https://t.co/qzfbkq5UFF}]}, url={urls=[{indices=[0.0, 23.0], display_url=dazn.com, url=https://t.co/djDxFCXzkt, expanded_url=http://www.dazn.com/}]}}, favourites_count=3495.0, time_zone=null, lang=null, followers_count=435246.0, friends_count=2046.0, follow_request_sent=false, has_extended_profile=false, geo_enabled=true, protected=false, url=https://t.co/djDxFCXzkt, listed_count=1987.0, profile_sidebar_border_color=000000, profile_background_color=000000, id_str=725265957866901505, name=DAZN Japan, translator_type=none, following=false, profile_link_color=FAB81E, profile_background_image_url_https=https://abs.twimg.com/images/themes/theme1/bg.png,
"

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

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

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

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

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

macaron_xxx

2020/09/24 02:33

statusesやurlsは配列なので、ループで回すなりする必要があるのでは。
pepe4422

2020/09/24 13:28

ご回答いただきましてありがとうございます、ループが必要なのですね。 色々と試しておりますが、やはりうまく取得することができません。。。 textであれば取得できたのですが、urlはうまく指定できていない?のでしょうか。。。 ◆エラーメッセージ TypeError: Cannot read property 'description' of undefined ◆ソースコード function twitterSearch(){ var twitterService = getService(); var sheet = SpreadsheetApp.getActive().getSheetByName('AAA'); var json = twitterService.fetch("https://api.twitter.com/1.1/search/tweets.json?q=横浜FC&result_type=popular&count=5"); var array = JSON.parse(json); for(let item of array.statuses.entities.description.urls){ Logger.log(item[0]); } }
macaron_xxx

2020/09/24 21:49

ですから、statusesもurlsも配列なので、それぞれループが必要です。 array.statuses[0].entities.urls[0].url これで取得できませんか?
pepe4422

2020/09/25 03:06 編集

コメントいただいた内容を理解できておらず申し訳ありません、いただいた記述で試してみたところ無事取得することができました! 大変助かりました、ありがとうございました。 追記)  回答欄からご回答いただけていないため、評価を差し上げることができませんでした。。。  お手数ですがご記入いただき次第、評価をさせていただきます。  よろしくお願いいたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問