您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

Python实现将sqlite数据库导出转成Excel(xls)表的方法

5b51 2022/1/14 8:16:50 python 字数 5589 阅读 339 来源 www.jb51.cc/python

本文实例讲述了Python实现将sqlite数据库导出转成Excel(xls)表的方法。分享给大家供大家参考,具体如下:

概述

本文实例讲述了Python实现将sqlite数据库导出转成Excel(xls)表的方法分享给大家供大家参考,具体如下:

1. 假设已经安装带有sliqte 库的Python环境

我的是Python2.5

2. 下载 python xls 写操作包(xlwt)并安装

下载地址: http://pypi.python.org/pypi/xlwt

3. 下面就是代码(db2xls.py):

import sqlite3 as sqlite
from xlwt import *
#MASTER_COLS = ['rowid','type','name','tbl_name','rootpage','sql']
def sqlite_get_col_names(cur,table):
  query = 'select * from %s' % table
  cur.execute(query)
  return [tuple[0] for tuple in cur.description]
def sqlite_query(cur,table,col = '*',where = ''):
  if where != '':
    query = 'select %s from %s where %s' % (col,where)
  else:
    query = 'select %s from %s ' % (col,table)
  cur.execute(query)
  return cur.fetchall()
def sqlite_to_workbook(cur,workbook):
  ws = workbook.add_sheet(table)
  print 'create table %s.' % table
  for colx,heading in enumerate(sqlite_get_col_names(cur,table)):
      ws.write(0,colx,heading)
  for rowy,row in enumerate(sqlite_query(cur,table)):
    for colx,text in enumerate(row):
      ws.write(rowy+ 1,text)
def main(dbpath):
  xlspath = dbpath[0:dbpath.rfind('.')] + '.xls'
  print "<%s> --> <%s>"% (dbpath,xlspath)
  db = sqlite.connect(dbpath)
  cur = db.cursor()
  w = Workbook()
  for tbl_name in [row[0] for row in sqlite_query(cur,'sqlite_master','type = \'table\'')]:
    sqlite_to_workbook(cur,tbl_name,w)
  cur.close()
  db.close()
  if tbl_name !=[]: w.save(xlspath)
if __name__ == "__main__":
  # arg == database path
  main(sys.argv[1])

4. 用法:

> python  <path>/db2xls.py  dbpath

如果没错,会在数据库的目录下生成同名的xls文件

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python常见数据库操作技巧汇总》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总

希望本文所述对大家Python程序设计有所帮助。

总结

以上是编程之家为你收集整理的Python实现将sqlite数据库导出转成Excel(xls)表的方法全部内容,希望文章能够帮你解决Python实现将sqlite数据库导出转成Excel(xls)表的方法所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶