Python3 操作Excel
- 环境: python3.11
- 系统: ubuntu20.04
- 使用依赖: openpyxl
1. 安装依赖
pip install openpyxl
跳转官网
2. 使用
2.1 创建工作簿
from openpyxl import Workbook
wb = Workbook()
工作簿至少要包含一个工作表(sheet), 可以使用如下来获取它
ws = wb.active
也可以创建自定义名称的工作表
ws1 = wb.create_sheet("name1")
2.2 查看工作簿下的所有工作表
print(wb.sheetnames)
2.3 访问/修改某个单元格数据
比如说修改A1单元格位置的参数
ws["A1"] = "姓名"
2.4 保存为文件
wb = Workbook()
wb.save('test.xlsx')
2.5 设置全局文字居中
from openpyxl import Workbook
from openpyxl.styles import Alignment
wb = Workbook()
sheet_name = "基础原料"
ws = wb.create_sheet(index=0, title=sheet_name)
# 填充标题内容 A1-C1
ws["A1"] = "名称"
ws["B1"] = "价格"
ws["C1"] = "描述"
# 设置居中样式
align = Alignment(horizontal='center', vertical='center', wrap_text=True)
# 设置所有文本居中对齐
for row in ws.iter_rows():
for cell in row:
cell.alignment = align
# 保存
wb.save('material.xlsx')
2.6 单元格增加备注
from openpyxl import Workbook
from openpyxl.styles import Alignment
from openpyxl.comments import Comment
wb = Workbook()
sheet_name = "基础原料"
ws = wb.create_sheet(index=0, title=sheet_name)
# 填充标题内容 A1-C1
ws["A1"] = "名称"
ws["B1"] = "价格"
ws["C1"] = "描述"
# 给A1单元格增加备注
a1_coment = Comment(text="该单元格为名称", author="开发者(作者)")
ws["A1"].comment = a1_coment
# 设置居中样式
align = Alignment(horizontal='center', vertical='center', wrap_text=True)
# 设置所有文本居中对齐
for row in ws.iter_rows():
for cell in row:
cell.alignment = align
# 保存
wb.save('material.xlsx')
2.7 合并单元格
ws.merge_cells(range_string='A1:B3')
如果在合并之前单元格中有数据,在合并之后数据可能会覆盖成空白,建议在使用时,先做结构,先合并之后,在插值文章来源:https://www.toymoban.com/news/detail-828903.html
2. 8 以流形式返回
以Django为例文章来源地址https://www.toymoban.com/news/detail-828903.html
from django.http import HttpResponse
from openpyxl import Workbook
from openpyxl.styles import Alignment
from openpyxl.comments import Comment
def export_data():
wb = Workbook()
sheet_name = "基础原料"
ws = wb.create_sheet(index=0, title=sheet_name)
# 填充标题内容 A1-C1
ws["A1"] = "名称"
ws["B1"] = "价格"
ws["C1"] = "描述"
# 给A1单元格增加备注
a1_coment = Comment(text="该单元格为名称", author="开发者(作者)")
ws["A1"].comment = a1_coment
# 设置居中样式
align = Alignment(horizontal='center', vertical='center', wrap_text=True)
# 设置所有文本居中对齐
for row in ws.iter_rows():
for cell in row:
cell.alignment = align
# 导出excel 表
response = HttpResponse(content_type="application/msexcel")
response["Access-Control-Expose-Headers"] = f"Content-Disposition"
response[
"Content-Disposition"
] = f'attachment;filename={quote(str(f"原料模板导出.xlsx"))}'
wb.save(response)
return response
到了这里,关于python基于openpyxl操作excel的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!