我已经为这个问题苦苦挣扎了一个多小时。我正在尝试使用 dbf 表创建一个 Sqlite 数据库。当我创建一个从 dbf 派生的记录列表以用作 Sqliteexecutemany
语句的输入时,Sqlite 表为空。当我尝试以交互方式使用 Python 复制问题时,Sqlite 执行成功。从 dbf 生成的列表在我运行它时被填充 - 所以问题出在executemany
语句中。
import sqlite3
from dbfpy import dbf
streets = dbf.Dbf("streets_sample.dbf")
conn = sqlite3.connect('navteq.db')
conn.execute('PRAGMA synchronous = OFF')
conn.execute('PRAGMA journal_mode = MEMORY')
conn.execute('DROP TABLE IF EXISTS STREETS')
conn.execute('''CREATE TABLE STREETS
(blink_id CHAR(8) PRIMARY KEY,
bst_name VARCHAR(39),
bst_nm_pref CHAR(2));''')
alink_id = []
ast_name = []
ast_nm_pref = []
for i in streets:
alink_id.append(i["LINK_ID"])
ast_name.append(i["ST_NAME"])
ast_nm_pref.append(i["ST_NM_PREF"])
streets_table = zip(alink_id, ast_name, ast_nm_pref)
conn.executemany("INSERT OR IGNORE INTO STREETS VALUES(?,?,?)", streets_table)
conn.close()