繁体   English   中英

Python sqlite3 错误-executemany function

[英]Python sqlite3 error -executemany function

我正在从文本文件导入数据,

1,A1,芝加哥。

2,B1,纽约。

3,K2,洛杉矶。

d=open('file.txt','r')
data=d.readlines()
data1=[]
for items in data:
    data1=items.split()
    #print(data1)
    stmt = "INSERT INTO Student1 VALUES (?,?,?)"
    cu.executemany(stmt, data1)```


I am getting this error.
cu.executemany(stmt, data1)
sqlite3.ProgrammingError: Incorrect number of bindings supplied. The current statement uses 4, and there are 2 supplied.

要使用“executemany”,您需要传递元组列表:

conn = sqlite3.connect('test.db')
cu = conn.cursor()
d = open('file.txt', 'r')
data = d.readlines()
data1 = []
for items in data:
    data1 += [items.split()]
stmt = "INSERT INTO Student1 VALUES (?,?,?,?)"
cu.executemany(stmt, data1)
conn.commit()

使用 executemany 插入行列表。 或者改为“执行”

for items in data:
    data1=items.split()
    #print(data1)
    stmt = "INSERT INTO Student1 VALUES (?,?,?)"
    cu.execute(stmt, data1)

executemany() 这个 function 需要第二个参数作为 python 中的元组列表。代码中的 data1 变量是没有元组的列表。 你可以使用类似下面的东西。

import sqlite3
d=open('file.txt','r')
data=d.readlines()
data1=[]
data1_in_list_of_tuple = []
for items in data:
    data1=items.split()
    data1_in_list_of_tuple.append(tuple(data1))
stmt = "INSERT INTO Student1 VALUES (?,?,?)"
cu.executemany(stmt, data1_in_list_of_tuple)

由于您一次只插入一名学生,因此请改用cursor.execute

创建数据(基本上等同于读取文件):

In [1]: txt = '''1, A1, chicago.
   ...: 2, B1, NY.
   ...: 3, K2, LA.'''
Out[1]: '1, A1, chicago.\n2, B1, NY.\n3, K2, LA.'

In [2]: data = txt.splitlines()
Out[2]: ['1, A1, chicago.', '2, B1, NY.', '3, K2, LA.']

用于正确的数据处理;

  • 删除. 在每一行的末尾。
  • split, ,
  • strip所有零件。

让我们测试如何做到这一点:

In [4]: item = [j.strip() for j in data[0][:-1].split(",")]
Out[4]: ['1', 'A1', 'chicago']

这看起来不错。

创建数据库和表(注意我已经编造了字段名称):

In [5]: import sqlite3

In [6]: con = sqlite3.connect(':memory:')
Out[6]: <sqlite3.Connection at 0x80414cd50>

In [7]: cur = con.cursor()
Out[7]: <sqlite3.Cursor at 0x8041aab20>

In [8]: cur.execute("CREATE TABLE Student1 (num INTEGER, grade TEXT, location TEXT)")
Out[8]: <sqlite3.Cursor at 0x8041aab20>

现在我们可以插入所有学生:

In [9]: for line in data:
   ...:     items = tuple(j.strip() for j in line[:-1].split(","))
   ...:     cur.execute("INSERT INTO Student1 VALUES (?,?,?)", items)
   ...:    

检查它是否有效:

In [10]: for row in cur.execute("SELECT * FROM Student1"):
    ...:     print(row)
    ...:     
(1, 'A1', 'chicago')
(2, 'B1', 'NY')
(3, 'K2', 'LA')

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM