【openpyxl】+【pandas】生成.xlsx
import pandas as pd
from sqlalchemy import create_engine
engine = create_engine("mysql+pymysql://root:123456@localhost:3306/scoresys")
sql = "SELECT id '学号',name '姓名',chinese '语文',math '数学',english '英语',science '科学',sports '体育',art '艺术' FROM student"
df = pd.read_sql(sql, engine)
df.to_excel(r'E:\学生成绩表.xlsx', index=False)
【xlwt】生成.xlsx
import pymysql
import xlwt
conn = pymysql.connect(host='localhost', port=3306, user='root', password="123456", db="scoresys")
cur = conn.cursor()
sql = "SELECT id '学号',name '姓名',chinese '语文',math '数学',english '英语',science '科学',sports '体育',art '艺术' FROM student"
cur.execute(sql)
fields = cur.description
rows = cur.fetchall()
cur.scroll(0, mode='absolute')
cur.close()
conn.close()
workbook = xlwt.Workbook(encoding='utf-8', style_compression=0)
style = xlwt.XFStyle()
font = xlwt.Font()
font.name = "微软雅黑"
style.font = font
sheet = workbook.add_sheet("用户信息", cell_overwrite_ok=True)
'''创建excel的列名'''
for field in range(len(fields)):
sheet.write(0, field, fields[field][0], style)
for row in range(1, len(rows) + 1):
for col in range(len(fields)):
sheet.write(row, col, rows[row - 1][col])
workbook.save(r"E:\学生成绩表.xls")
【openpyxl】生成.xlsx
import pymysql
import openpyxl
conn = pymysql.connect(host='localhost', port=3306, user='root', password="123456", db="scoresys")
sql = "SELECT id '学号',name '姓名',chinese '语文',math '数学',english '英语',science '科学',sports '体育',art '艺术' FROM student"
cur = conn.cursor()
cur.execute(sql)
result = cur.fetchall()
cur.close()
conn.close()
book = openpyxl.Workbook()
sheet = book.active
h1 = [filed[0] for filed in cur.description]
sheet.append(h1)
for i in result:
sheet.append(i)
book.save(r"E:\学生成绩表.xls")