首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Python和sqlite3 -导入和导出数据库

Python和sqlite3 -导入和导出数据库
EN

Stack Overflow用户
提问于 2011-01-18 07:45:44
回答 2查看 20.5K关注 0票数 16

我正在尝试编写一个脚本来导入数据库文件。我像这样编写了导出文件的脚本:

代码语言:javascript
复制
import sqlite3

con = sqlite3.connect('../sqlite.db')
with open('../dump.sql', 'w') as f:
    for line in con.iterdump():
        f.write('%s\n' % line)

现在,我希望能够导入该数据库。我试过了:

代码语言:javascript
复制
import sqlite3

con = sqlite3.connect('../sqlite.db')
f = open('../dump.sql','r')
str = f.read()
con.execute(str)

但我不能执行多条语句。有没有办法让它直接运行SQL脚本?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-18 07:50:19

代码语言:javascript
复制
sql = f.read() # watch out for built-in `str`
cur.executescript(sql)

Documentation

票数 19
EN

Stack Overflow用户

发布于 2011-01-18 07:50:39

尝试使用

代码语言:javascript
复制
con.executescript(str)

文档

代码语言:javascript
复制
Connection.executescript(sql_script)
    This is a nonstandard shortcut that creates an intermediate cursor object
    by calling the cursor method, then calls the cursor’s executescript
    method with the parameters given.

或者先创建光标

代码语言:javascript
复制
import sqlite3

con = sqlite3.connect('../sqlite.db')
f = open('../dump.sql','r')
str = f.read()
cur = con.cursor()
cur.execute(str)
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4719159

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档