把库中的表,导出为excel

上次记录的导表,有一个问题,就是当表比较大的时候,超过电脑内存,
程序就会有问题,这次采用 分批存入,后续追加。
但是验证后,还有问题,没达到预期目的。先记录一下吧。

#!/usr/bin/python
#coding=UTF-8
import xlwt
import MySQLdb
import conf
import sys
import xlrd
import datetime
from xlutils.copy import copy
reload(sys)
sys.setdefaultencoding('utf8')
def get_data(sql):
    conn = MySQLdb.connect(conf.sh_dbhost,conf.sh_user,conf.sh_passd,conf.sh_dbname,charset="utf8")
    cur = conn.cursor()
    cur.execute(sql)
    results = cur.fetchall() # 搜取所有结果
    cur.close()
    conn.close()
    return results
def write_fild_to_excel(filename,sql):
    workbook = xlwt.Workbook()
    sheet = workbook.add_sheet('sheetname',cell_overwrite_ok=True)
    fields = get_data(sql)
    for field in range(0,len(fields)):
        sheet.write(0,field,u'%s'%fields[field][0])
    workbook.save(filename)
def write_data_to_excel(filename,sql):
    results =get_data(sql)
    workbook = xlrd.open_workbook(filename,'f')
    worksheet = workbook.sheet_by_index(0)
    nrows = worksheet.nrows
    wb = copy(workbook)
    ws = wb.get_sheet(0)
    for row in range(1,len(results)+1):
        for col in range(0,len(results[0])):
            ws.write(row+nrows-1,col,u'%s'%results[row-1][col])
    wb.save(filename)
if __name__ == "__main__":
    sql_fild = "SELECT column_name FROM information_schema.columns WHERE Table_name= '%s'" %conf.sh_table
    sql_data = "SELECT * FROM tb_product ORDER BY product_id DESC limit 4000"
    write_fild_to_excel(r'E:\yu.xls',sql_fild)
    write_data_to_excel(r'E:\yu.xls',sql_data)
    print "done"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhizunyu2009

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值