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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

0回答

753閲覧

pythonでTwitterの投稿内容から指定の文言を含む投稿を抽出し、csvにエクスポートしたいです。

hide09090909

総合スコア68

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2022/02/19 13:52

何度か同じような質問をしており、申し訳ないのですが
pythonで任意の単語を指定するとツイッターからその単語が含まれる投稿情報をcsvに出力するコードを作成したいです。
下記サイトを参考にAPIの使用承認を取り、作成したのですが、■エラー内容 に記載のエラーが表示され実行できません。
どなたか原因わかりますでしょうか?また、その他動作のために良くない記載箇所があれば教えていただけますと幸いです。
https://qiita.com/penguinprogrammer/items/b220be0c203eaaad015a
https://toxublog.com/blog/get_tweet_tweepy/#ok

#ライブラリのインポート import tweepy from datetime import datetime,timezone import pytz import pandas as pd #Twitterの認証 api_key = "xxxxxx" api_secret = "xxxxxx" access_key = "xxxxxx-xxxxxx" access_secret = "xxxxxx" auth = tweepy.OAuthHandler(api_key, api_secret) auth.set_access_token(access_key, access_secret) api = tweepy.Client(auth) #検索条件の設定 searchkey = 'プログラミング' item_num = 10 #検索条件を元にツイートを抽出 tweets = tweepy.Cursor(api.search_tweets,q=searchkey,lang='ja').items(item_num) #関数: UTCをJSTに変換する def change_time_JST(u_time): #イギリスのtimezoneを設定するために再定義する utc_time = datetime(u_time.year, u_time.month,u_time.day, \ u_time.hour,u_time.minute,u_time.second, tzinfo=timezone.utc) #タイムゾーンを日本時刻に変換 jst_time = utc_time.astimezone(pytz.timezone("Asia/Tokyo")) # 文字列で返す str_time = jst_time.strftime("%Y-%m-%d_%H:%M:%S") return str_time #抽出したデータから必要な情報を取り出す #取得したツイートを一つずつ取り出して必要な情報をtweet_dataに格納する tweet_data = [] for tweet in tweets: #ツイート時刻とユーザのアカウント作成時刻を日本時刻にする tweet_time = change_time_JST(tweet.created_at) create_account_time = change_time_JST(tweet.user.created_at) #tweet_dataの配列に取得したい情報を入れていく tweet_data.append([ tweet.id, tweet_time, tweet.text, tweet.favorite_count, tweet.retweet_count, tweet.user.id, tweet.user.screen_name, tweet.user.name, tweet.user.description, tweet.user.friends_count, tweet.user.followers_count, create_account_time, tweet.user.following, tweet.user.profile_image_url, tweet.user.profile_background_image_url, tweet.user.url ]) #取り出したデータをpandasのDataFrameに変換 #CSVファイルに出力するときの列の名前を定義 labels=[ 'ツイートID', 'ツイート時刻', 'ツイート内容', 'いいね数', 'リツイート数', 'ID', 'ユーザID', 'アカウント名', '自己紹介文', 'フォロー数', 'フォロワー数', 'アカウント作成日時', '自分がフォローしているか?', 'アイコン画像URL', 'ヘッダー画像URL', 'WEBサイト' ] #tweet_dataのリストをpandasのDataFrameに変換 df = pd.DataFrame(tweet_data,columns=labels) #CSVファイルに出力する #CSVファイルの名前を決める file_name='tweet_data.csv' #CSVファイルを出力する df.to_csv(file_name,encoding='utf-8-sig',index=False)

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問