[解決済み】sqlite3.ProgrammingError: 指定されたバインディングの数が正しくありません。現在の文は 1 を使用しており、74 が供給されています。
2022-02-09 20:43:13
質問
def insert(array):
connection=sqlite3.connect('images.db')
cursor=connection.cursor()
cnt=0
while cnt != len(array):
img = array[cnt]
print(array[cnt])
cursor.execute('INSERT INTO images VALUES(?)', (img))
cnt+= 1
connection.commit()
connection.close()
挿入しようとしている実際の文字列は74文字で、それは "/gifs/epic-fail-photos-there-i-fixed-it-aww-man-tire-pressures-low.gif" です。
挿入する前にstr(array[cnt])を試してみましたが、同じ問題が起こっています、データベースには1列しかなく、それはTEXT値なんです。
何時間もやっていますが、何が起こっているのかがわかりません。
解決方法は?
シーケンスを渡す必要があるが、パラメータをタプルにするためにカンマを忘れている。
cursor.execute('INSERT INTO images VALUES(?)', (img,))
コンマ抜きで
(img)
はタプルではなく単なるグループ化された表現なので
img
の文字列が入力シーケンスとして扱われます。もしその文字列が74文字であれば、Pythonはそれを74個の別々のバインド値、それぞれ1文字の長さとして見なします。
>>> len(img)
74
>>> len((img,))
1
読みやすいと感じたら、リスト・リテラルを使うこともできます。
cursor.execute('INSERT INTO images VALUES(?)', [img])
関連
-
ピロウズ画像色処理の具体的な活用方法
-
Pythonの学習とデータマイニングのために知っておくべきターミナルコマンドのトップ10
-
PythonによるExcelファイルの一括操作の説明
-
[解決済み】DataFrameのコンストラクタが正しく呼び出されない!エラー
-
[解決済み】TypeError: 系列を <class 'float'> に変換することができません。
-
[解決済み】NameError: 名前 'self' が定義されていません。
-
[解決済み】cアンダースコア式`c_`は、具体的に何をするのですか?
-
[解決済み】 'numpy.float64' オブジェクトは反復可能ではない
-
[解決済み] オブジェクトの現在のプロパティと値をすべて表示する組み込み関数はありますか?
-
[解決済み】type()とisinstance()の違いは何ですか?)
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Python jiabaライブラリの使用方法について説明
-
python implement mysql add delete check change サンプルコード
-
Python interpreted model libraryによる機械学習モデル出力の可視化 Shap
-
pyCaret効率化乗算器 オープンソース ローコード Python機械学習ツール
-
任意波形を生成してtxtで保存するためのPython実装
-
[解決済み】 NameError: グローバル名 'xrange' は Python 3 で定義されていません。
-
[解決済み】Pythonでgoogle APIのJSONコードを読み込むとエラーになる件
-
[解決済み】 AttributeError("'str' object has no attribute 'read'")
-
[解決済み】Flask ImportError: Flask という名前のモジュールがない
-
[解決済み】 'numpy.float64' オブジェクトは反復可能ではない