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

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

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

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Python 3.x

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

Twitter

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

0回答

558閲覧

tweepyとsqlite3で最新のつぶやきをDBに正しく格納したい

kalon

総合スコア198

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Python 3.x

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

Twitter

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/12/06 06:50

編集2022/01/12 10:55

皆様いつもお世話になっております。

Python Python 3.6.5
sqlite3 3.28.0

python

1import tweepy 2import sqlite3 3 4# 認証キーの設定 5consumer_key = \ 6 "XXXXXXXX" 7consumer_secret = "XXXXXXXX" 8access_token = "XXXXXXXX" 9access_token_secret = "XXXXXXXX" 10 11# OAuth認証 12auth = tweepy.OAuthHandler(consumer_key, consumer_secret) 13auth.set_access_token(access_token, access_token_secret) 14 15 16class Database: 17 def __init__(self): 18 self.dbpath = 'db.sqlite3' 19 self.conn = sqlite3.connect(self.dbpath) 20 self.c = self.conn.cursor() 21 22 23db = Database() 24 25 26def output_users_from_db(): 27 return db.c.execute('select name, comment from twitter_users') 28 29 30def update_comment(name, comment='null'): 31 db.c.execute("""update twitter_users set comment = ? where name = ?""", (comment, name)) 32 db.conn.commit() 33 34if __name__ == "__main__": 35 api = tweepy.API(auth) 36 users_info_from_db = output_users_from_db() 37 for i, user_info_on_db in enumerate(users_info_from_db): 38 39 print(user_info_on_db[0]) 40 41 time_line = api.user_timeline(screen_name=user_info_on_db[0]) 42 for i, info in enumerate(time_line): 43 print(info.text) 44 update_comment(user_info_on_db[0], info.text) 45 break

本来なら以下のようにDBに入ると思うのですが、

sqlite3

1 2select * from twitter_users; 3 4aichan_nel|( ⁎ᵕᴗᵕ⁎ ) 5この顔文字お気に入りに入れてたの 6にあんま使ってないことに気づいたAIが 7 813:09を、お知らせします。 9( ⁎ᵕᴗᵕ⁎ )✨ 10 11 12SIROyoutuber|12/29 18:30~さいたまスーパーアリーナのコミュニティアリーナにて開催の『V-RIZIN』2019に参加します┣¨ ୧(๑ ⁼̴̀ᐜ⁼̴́๑)૭ ン! 13バーチャル世界と格闘技イベントの融合を図るエンターテイメントイベント!???? 14 15応援を力に変えるから、めいっぱい暴れようね!???? 16https://vtuber-rizin.jp 17VRIZIN2019

以下のように保存されてしまいます

sqlite3

1sqlite> select * from twitter_users; 2aichan_nel|@lesupo_ru321id (っ´ڡ`)╮ =͟͟͞͞( ⁎ᵕᴗᵕ⁎ )✨ 3SIROyoutuber| 4
  1. 一番外側のfor文の1週目でキズナアイの最新のつぶやきがDBに登録される。
  2. 一番外側のfor文の二週目で電脳少女シロの最新のつぶやきがDBに保存される。

という動きを想像していました。
なぜ、SIROyoutuberのつぶやきの日本語や記号、リンクなどが保存されないのか分かりません。

補足ですが、二番目のループ内で

python

1print(user_info_on_db[0]) 2print(info.text)

すると、DB上の1番目のキズナアイと2番目の電脳少女シロの最新のつぶやきが出力されるのですが、なぜかupdate_comment(user_info_on_db[0], info.text)を入れると、キズナアイのつぶやきしか出力されません。どうすれば二番目の電脳少女シロのつぶやきをprint出力し、更にDBに保存できるでしょうか?

アドバイスとご教授のほどよろしくお願いします。

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

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

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

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

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

quickquip

2019/12/06 07:18

「本来なら以下のように」「正しく保存されない」というのがどういうことか説明してもらえますか? 今は"書いたソースの通りに動いている"状況ですからこれが"正しい"動作です。他の人が見て「こう書いたらこういう結果になるよね」というような判断はできます。 ですがそれに対して、"書いた人が想定している動作"の方は説明してもらわないかぎり他の人には決してわかりません。
quickquip

2019/12/06 07:47

1行目はこれが保存されていると思いました。 https://twitter.com/aichan_nel/status/1202817297070481408 この結果自体に不思議な点はないです。「本来なら以下のように」でどういう状態を「本来」と言っているのかやっぱりわからないです。 2行目のcommentカラムが空なことが問題なのでしょうか? print(info.text) の行で出力されたものがSQLite3に保管されていないというのが質問の主旨なのでしょうか?
kalon

2019/12/06 07:51

quiqui様 度々のご指摘ありがとうございます。 >1行目はこれが保存されていると思いました。 >https://twitter.com/aichan_nel/status/1202817297070481408 最新のリプライが取得されるのですね。気付きませんでした。 >2行目のcommentカラムが空なことが問題なのでしょうか? はい。そのとおりです。
quickquip

2019/12/06 07:53 編集

> 最新のリプライが取得されるのですね。気付きませんでした。 いえ。取得したデータの中でこれがたまたま最初だっただけでしょう。
quickquip

2019/12/06 07:58

逆にどんな動きだと思っていたのか? がこちらには分からないのでそれを書いて欲しいわけです。
kalon

2019/12/06 08:01

1. 一番外側のfor文の1週目でキズナアイの最新のつぶやきがDBに登録される。 2. 一番外側のfor文の二週目で電脳少女シロの最新のつぶやきがDBに保存される。 という動きを想像していました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問