尝试pandas导出数据库数据到excel

 

from math import ceil

import pandas as pd
from openpyxl import load_workbook
import pymysql


def getDataFromMysql():
    """
    连接数据库

    """

    conn = pymysql.connect(host='127.0.0.1', user="xxx", passwd="xxx", db="xxx", port=3306, charset="utf8")
    cur = conn.cursor()
    cur.execute("select * from movies")
    movies = cur.fetchall()
    cur.close()
    conn.close()

    return movies


def dataFrame2sheet(dataframe, excelWriter, countn):
    """
    pandas dataframe生成excel

    """
    # DataFrame转换成excel中的sheet表
    dataframe.to_excel(excel_writer=excelWriter, sheet_name="info_{0}".format(countn), index=None)

    excelWriter.save()
    excelWriter.close()


"""
excel中新增sheet表
"""


def excelAddSheet(dataframe, excelWriter, i):
    """
    在excel中新增sheet表
    """
    book = load_workbook(excelWriter.path)
    excelWriter.book = book

    dataframe.to_excel(excel_writer=excelWriter, sheet_name="info_{0}".format(i), index=None)

    excelWriter.close()


if __name__ == '__main__':

    movies = getDataFromMysql()
    dataSet = []
    for i in movies:
        dataSet.append(list(i))

    # excelPath
    excelPath = "./test.xlsx"

    # 生成DataFrame
    countn = ceil(len(dataSet) / 200)
    if countn <= 1:

        dataframe = pd.DataFrame(dataSet[:200])

        # 创建ExcelWriter 对象
        excelWriter = pd.ExcelWriter(excelPath, engine='openpyxl')

        # 生成excel

        dataFrame2sheet(dataframe, excelWriter, countn)

    # excel中增加sheet
    else:
        # 使用公共的excelWriter,数据不会被覆盖
        excelWriter = pd.ExcelWriter(excelPath, engine='openpyxl')
        for i in range(1, countn + 1):
            dataframe = pd.DataFrame(dataSet[(i - 1) * 200:i * 200])


            # 在excel里增加sheet,并写入数据。这个也可以实现
            # excelAddSheet(dataframe, excelWriter, i)
            
            # 生成excel
            dataFrame2sheet(dataframe, excelWriter, countn=i)
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值