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

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

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

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

Python

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

Q&A

解決済

1回答

1156閲覧

Python&sqlite3 inputで取得した文字列をテーブルに挿入したい

tetsuya19

総合スコア19

SQLite

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

Python

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

0グッド

0クリップ

投稿2021/12/24 13:42

前提環境:Windows10 / Python3.9.2 / sqlite3 3.37

実現したい事:Pythonからsqlite3にinputで得た文字列を
テーブルのデータに挿入したいです。

例:input_value = input()

上記のinput_valueの値(文字列)をsqlite3のテーブルに格納したいです。
文字列は、ひとまとまりのデータとしてテーブルに格納したいです。

※データベースとテーブルには既に接続確認済です。
下記の構文が何か間違っているようですが、教えて頂ければ幸いです。
18行目→ conn.executemany("insert into tbl_name2 values( ? )", [input_value])

エラーメッセージ

calculator.py", line 18, in calculate
conn.executemany("insert into tbl_name2 values( ? )", [input_value])
sqlite3.ProgrammingError: Incorrect number of bindings supplied. The current statement uses 1, and there are 13 supplied

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

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

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

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

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

Supernove

2021/12/24 13:51 編集

エラーの行だけ見せられてもエラーが分かるわけないのでちゃんと全部のせてください。 もしかしたら、この定義を行う前のところで何か問題があるかもしれないので念の為載せてもらえるとありがたいです
tetsuya19

2021/12/24 14:08

ご指摘ありがとうございます。 失礼致しました。以後全部コードは記載するように気を付けます。
guest

回答1

0

ベストアンサー

前回の質問と同様にタプルのリストにします。

python

1import sqlite3 2 3conn = sqlite3.connect("test2.db") 4conn.execute("create table if not exists tbl_name2(name)") 5 6input_value = input() 7conn.executemany("insert into tbl_name2 values( ? )", [(input_value,)]) 8conn.commit()

bash

1$ python insert_to_db.py 2a b c d 1 2 3 4 3 4$ sqlite3 test2.db 5SQLite version 3.34.1 2021-01-20 14:10:07 6sqlite> select * from tbl_name2; 7a b c d 1 2 3 4

投稿2021/12/24 13:54

編集2021/12/24 13:56
melian

総合スコア20369

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

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

tetsuya19

2021/12/24 14:11 編集

ご解答ありがとうございます。 [(input_value,)]のように()を付けてカンマ","を付けないと いけなかったんですね。タプル型にする、,を忘れず付ける、大変勉強になりました。 同様の内容のことを質問しないように、気を付けます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.39%

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

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

質問する

関連した質問