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

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

ただいまの
回答率

89.98%

pythonからmysqlの操作(insert)がわからない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 592

lasagna0209

score 9

前提・実現したいこと

twitterAPIを使いツイートを取得し、mysqlに入れたいのですが、insertの書き方が分かりません。
config.py には各々のキーを書いています

該当のソースコード

from requests_oauthlib import OAuth1Session
import json, config
import mysql.connector

CK = config.CONSUMER_KEY
CS = config.CONSUMER_SECRET_KEY
AT = config.ACCESS_TOKEN
ATS = config.ACCESS_TOKEN_SECRET

twitter = OAuth1Session(CK, CS, AT, ATS)

url = "https://api.twitter.com/1.1/search/tweets.json"

keyword = input('>> ')

params = {'q': keyword, 'count': 100}

for i in params:
    req = twitter.get(url, params=params)

    if req.status_code == 200:
        search_timeline = json.loads(req.text)
        for tweet in search_timeline['statuses']:
            print(tweet['user']['name'] + '::' + tweet['text'])
            print(tweet['created_at'])

    else:
        print("ERROR: %d" % req.status_code)


connection = mysql.connector.connect(db="twitter")
cursor = connection.cursor()
cursor.execute("CREATE TABLE justatest (name TEXT, content TEXT)")

data = []
for i in data:


```
cur.execute("INSERt INTO justatest(name,content) VALUES  ・・・?

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • gh640

    2019/01/16 15:44

    コードはご自身で書かれたものですか?拝見するかぎり変数の使い方がおわかりになっていないようには見えませんが、何がわからない感じでしょう。

    キャンセル

  • gh640

    2019/01/16 15:46

    ご質問の主旨である「 insert の書き方」については https://dev.mysql.com/doc/connector-python/en/connector-python-example-cursor-transaction.html で説明されているので、こちらがご参考になるかと思います。いかがでしょう。

    キャンセル

  • lasagna0209

    2019/01/16 23:20

    自分で書いたものです。
    分からない部分はやはりinsert部分です。公式ドキュメントでは入れるデータを変数data_employee,data_salaryと一つずつ定義していますが、そうではなく、今回のように100件のツイートを一斉にやるやり方が分かりません。

    キャンセル

回答 1

checkベストアンサー

0

ご回答いただきありがとうございます。 1 件ずつ挿入する方法はわかるけれど複数件まとめて挿入する方法がわからない、ということですかね。

メソッドは executemany() というものを使って、 data の各要素はタプルにしておくとよいのではないかと思います。

次のようなコードにするとよいのではないでしょうか(私の手元では動作確認していないのでアイデアだけ参考にしていただければと思います)。

from requests_oauthlib import OAuth1Session
import json, config
import mysql.connector

CK = config.CONSUMER_KEY
CS = config.CONSUMER_SECRET_KEY
AT = config.ACCESS_TOKEN
ATS = config.ACCESS_TOKEN_SECRET

twitter = OAuth1Session(CK, CS, AT, ATS)

url = "https://api.twitter.com/1.1/search/tweets.json"

keyword = input('>> ')

params = {'q': keyword, 'count': 100}

# 変更点 1: data を for ループ前に移動
data = []
for i in params:
    req = twitter.get(url, params=params)

    if req.status_code == 200:
        search_timeline = json.loads(req.text)
        for tweet in search_timeline['statuses']:

            # 変更点 2: tweet の中身のうち、 name と content(text) を data に追加
            record = (tweet['user']['name'], tweet['text'])
            data.append(record)
            print(tweet['user']['name'] + '::' + tweet['text'])
            print(tweet['created_at'])

    else:
        print("ERROR: %d" % req.status_code)


connection = mysql.connector.connect(db="twitter")
cursor = connection.cursor()
cursor.execute("CREATE TABLE justatest (name TEXT, content TEXT)")

# 変更点 3: 前の for ループで蓄積した data をまとめて挿入
cursor.executemany("INSERT INTO justatest (name, content) VALUES (%s, %s)", data)

(変数 record はロジックをわかりやすくするために使っていますが、実際には data.append() にタプルを直接追加していただくとよいかと思います)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 89.98%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる