🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
タプル

タプルは、順序付けされた複数の要素で構成される組の集合数詞です。元々は数学の概念ですが、PythonやML、Haskellなどのプログラミング言語にはタプルという名称のデータ型が用意されています。

SQLite

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

Python

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

Q&A

解決済

1回答

2751閲覧

Python&Sqlite3 タプルの値をテーブルに格納したい

tetsuya19

総合スコア19

タプル

タプルは、順序付けされた複数の要素で構成される組の集合数詞です。元々は数学の概念ですが、PythonやML、Haskellなどのプログラミング言語にはタプルという名称のデータ型が用意されています。

SQLite

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

Python

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

0グッド

0クリップ

投稿2021/12/23 15:50

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

実現したい事:
Pythonでタプル型の値をsqlite3のテーブルに格納したいです。
下記エラーが出ていて実現出来ていません。
どなたかご教授お願い致します。

エラーメッセージ:
python sample3.py
line 5, in <module>conn.executemany("insert into tbl_name2 values( ? )",tuple)
sqlite3.ProgrammingError: Incorrect number of bindings supplied. The current statement uses 1, and there are 2 supplied.

該当のコード:sample3.py
import sqlite3
conn = sqlite3.connect("test2.db")
conn.execute("create table tbl_name2(name)")
tuple = ('山田','小林','中島')
conn.executemany("insert into tbl_name2 values( ? )",tuple)
conn.commit()
conn.close()

補足:
上記コード内の5行目
conn.executemany("insert into tbl_name2 values( ? )",tuple)
の記述がおかしいようなのですが、何が駄目なのかがわかりません。

データベースのファイル(test2.db)とテーブル(tbl_name2)自体は、
PupSQLiteで見て作成されているのを確認済です。

以上、ご解答宜しくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

sqlite3 - SQLite データベースに対する DB-API 2.0 インターフェース に載っているサンプルコードを見ますと、executemany() にはタプルのリストを渡す必要がありそうです。

python

1import sqlite3 2 3conn = sqlite3.connect("test2.db") 4conn.execute("create table if not exists tbl_name2(name)") 5names = ('山田','小林','中島') 6conn.executemany("insert into tbl_name2 values( ? )", [(n,) for n in names]) 7conn.commit()

tuple という単語はクラス名として使われていますので names に変更しています

bash

1$ sqlite3 test2.db 2 3sqlite> .ta 4tbl_name2 5sqlite> .schema tbl_name2 6CREATE TABLE tbl_name2(name); 7sqlite> select * from tbl_name2; 8山田 9小林 10中島

投稿2021/12/23 16:21

melian

総合スコア20610

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

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

tetsuya19

2021/12/23 23:41

迅速なご解答を頂きありがとうございます。 ご提示頂いたコードで無事実行出来ました。 tupleがクラス名だとは知りませんでした。 また、参考サイトのURLもご紹介頂き、大変勉強になりました。 誠にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問