Python中通过文件将数据导入sqlite3
import sqlite3
# 假设有一个名为'data.txt'的文件,其中包含以逗号分隔的数据
data_file = 'data.txt'
db_name = 'example.db'
table_name = 'example_table'
# 连接到SQLite数据库
conn = sqlite3.connect(db_name)
cursor = conn.cursor()
# 创建表
cursor.execute(f'''CREATE TABLE IF NOT EXISTS {table_name}
(id INTEGER PRIMARY KEY, name TEXT, age INTEGER)''')
# 插入数据
with open(data_file, 'r') as file:
for line in file:
values = line.split(',') # 假设数据是逗号分隔的
cursor.execute(f"INSERT INTO {table_name} (name, age) VALUES (?, ?)",
(values[0], int(values[1]))) # 假设第一个字段是名称,第二个是年龄
# 提交事务并关闭连接
conn.commit()
conn.close()
这段代码展示了如何将一个文本文件中的数据导入SQLite数据库。在这个例子中,我们假设文件是一个简单的逗号分隔值(CSV)文件,其中包含两个字段:'name'和'age'。代码首先建立了一个表(如果它不存在的话),然后通过文件中的每一行,分割数据并将其插入到表中。在插入数据时,使用参数化查询来防止SQL注入攻击,并将年龄字段转换为整数类型。最后,提交事务并关闭数据库连接。
评论已关闭