皆様いつもお世話になっております。
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
- 一番外側のfor文の1週目でキズナアイの最新のつぶやきがDBに登録される。
- 一番外側の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に保存できるでしょうか?
アドバイスとご教授のほどよろしくお願いします。
あなたの回答
tips
プレビュー