python 使用 openpyxl 操作 excel


文章目录

  • python 使用 openpyxl 操作 excel
  • 前言
  • 1.环境
  • 2.读取数据
  • 3.openpyxl



前言

二、使用 zipfile、openpyxl、flask 批量导出excel zip


1.环境

openyxl:3.0.6

python:3.7.6

pandas:1.3.5

2.读取数据

#使用pandas读取数据
#https://pandas.pydata.org/docs/reference/api/pandas.read_excel.html#pandas.read_excel
pd.read_excel(path, sheet_name=None)

#flask form
pd.read_excel(request.files['file'], sheet_name=None)

具体操作

https://pandas.pydata.org/docs/reference/frame.html

3.openpyxl

加载excel

#加载excel
#https://pandas.pydata.org/docs/reference/api/pandas.read_excel.html#pandas.read_excel
wb = load_workbook('./src/statics/clean_production_tmp.xlsx')

创建excel

wb = Workbook()

e方法

参数

作用

返回

Workbook

get

wb.active

获取当前的sheet页

WorkSheet

Workbook

get

wb.get_sheet_by_name()

str

根据sheet名称获取sheet页

WorkSheet

Workbook

get

wb.copy_worksheet()

worksheet

根据参数 worksheet 复制worksheet

WorkSheet

Workbook

set

wb.remove(worksheet)

worksheet

根据参数 worksheet 复制worksheet

WorkSheet

WorkSheet

set

ws.column_dimensions[‘A’].width = 10

设置列宽

WorkSheet

set

ws.title = ‘123’

str

设置sheet标题

WorkSheet

set

ws.merge_cells(“A1:A4”)

set

合并单元格

保存excel

wb = Workbook()
wb.save('balances.xlsx')

通过接口返回

output = BytesIO()
wb_tmp = load_workbook('./src/statics/clean_production_tmp.xlsx')
wb_tmp.save(output)
output.seek(0)
resp = make_response(output.getvalue())
basename = '2022-3-7.xlsx'

# 转码,支持中文名称
resp.headers["Content-Disposition"] = "attachment; filename*=UTF-8''{utf_filename}".format(utf_filename=basename)
resp.headers['Content-Type'] = 'application/x-xlsx'
return resp