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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 3.x

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

Q&A

解決済

1回答

1165閲覧

Twitter api 401 Unauthorize の解決

SK_

総合スコア8

Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 3.x

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

0グッド

0クリップ

投稿2023/03/16 07:11

編集2023/03/16 07:46

実現したいこと

  • 正常にツイート収集を行えるようにする
  • エラーの解決

前提

twitter apiを用いてユーザータイムラインを収集していたところ,下記のエラーが発生しました.
言語はPythonです.
別でツイート収集のプログラムも使用していたのですが,そちらでも同じエラーが発生します.

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

Unauthorized: 401 Unauthorized 32 - Could not authenticate you.

該当のソースコード

Python

1import tweepy 2from datetime import datetime,timezone 3import pytz 4import pandas as pd 5 6#Twitterの認証 7api_key = "***" 8api_secret = "***" 9access_key = "***" 10access_secret = "***" 11auth = tweepy.OAuthHandler(api_key, api_secret) 12auth.set_access_token(access_key, access_secret) 13api = tweepy.API(auth) 14 15#検索条件の設定 16screen_name='***' 17item_num = 3200 18 19#検索条件を元にツイートを抽出 20tweets =tweepy.Cursor(api.user_timeline,count=200,screen_name=screen_name).items(item_num) 21 22#関数: UTCをJSTに変換する 23def change_time_JST(u_time): 24 #イギリスのtimezoneを設定するために再定義する 25 utc_time = datetime(u_time.year, u_time.month,u_time.day, \ 26 u_time.hour,u_time.minute,u_time.second, tzinfo=timezone.utc) 27 #タイムゾーンを日本時刻に変換 28 jst_time = utc_time.astimezone(pytz.timezone("Asia/Tokyo")) 29 # 文字列で返す 30 str_time = jst_time.strftime("%Y-%m-%d_%H:%M:%S") 31 return str_time 32 33#抽出したデータから必要な情報を取り出す 34#取得したツイートを一つずつ取り出して必要な情報をtweet_dataに格納する 35tweet_data = [] 36for tweet in tweets: 37 #ツイート時刻とユーザのアカウント作成時刻を日本時刻にする 38 tweet_time = change_time_JST(tweet.created_at) 39 create_account_time = change_time_JST(tweet.user.created_at) 40 #tweet_dataの配列に取得したい情報を入れていく 41 tweet_data.append([tweet.id, tweet_time, tweet.text, tweet.favorite_count, tweet.retweet_count]) 42 #取り出したデータをpandasのDataFrameに変換 43 #CSVファイルに出力するときの列の名前を定義 44 labels=['ツイートID' ,'ツイート時刻', 'ツイート内容', 'いいね数', 'リツイート数'] 45 46#tweet_dataのリストをpandasのDataFrameに変換 47df = pd.DataFrame(tweet_data,columns=labels) 48 49#CSVファイルに出力する 50#CSVファイルの名前を決める 51file_name='検証用_ツイート.csv' 52 53#CSVファイルを出力する 54df.to_csv(file_name,encoding='utf-8-sig',index=False)

試したこと

同様のエラーが出ている方がいるか調べましたが,その方も具体的な解決には至っていないようでした
https://qiita.com/tqwko_05/questions/17442873e4c87074a12d
トークンやキーの再生成は試しました.

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

Python3
アクセス権限:Elevated
application permission:Read

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

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

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

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

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

can110

2023/03/16 07:40

本物のようなアカウント情報が記載されているようですが問題ない(再作成済み)でしょうか。 なお、以下の私のアカウントでは提示コードでエラーなく動作しましたので参考まで。 Access = Elevated App permissions = Read and write and Direct message Type of App = Native App
can110

2023/03/16 07:58

なお「32 - Could not authenticate you.」から - api_keyまたはapi_secretが間違っている - アカウントが無効?になっている? 可能性がありそうなので https://bb-multi-tech.com/programing/twitter-error-code-32/ を参考に念のためアプリが「SUSPENDED」になっていないか確認してみてください。 (赤色で目立つのですぐに気づくと思いますが)
SK_

2023/03/16 08:04

早急の返答ありがとうございます. 気づかずに投稿してしまいました,ご指摘ありがとうございます. 一応再生成する前のものです. アプリのタイプの設定が間違えていたようです. Nativeにしたところ実行できました 最初に設定したときから変更していないつもりだったのですが,チェックが外れていたようです. 以前の質問に加えて今回も返答していただきありがとうございました.
SK_

2023/03/16 08:06

ベストアンサーに選出させていただきたいので お手数ですが,適当な回答をいただけますか
can110

2023/03/16 08:06

解決してよかったです。 アプリのタイプの変更で解決した旨の自己回答にて質問クローズください。
guest

回答1

0

自己解決

Type of app の設定が間違っていたようです.

投稿2023/03/16 08:09

SK_

総合スコア8

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問