目录
一、安装openpyxl库
python
pip install -i https://pypi.tuna.tsinghua.edu.cn/simpl openpyxl
二、openpyxl库介绍
1、工作簿
a、创建工作簿
python
openpyxl.Workbook() #创建一个新的工作簿对象。
b、加载工作簿
python
openpyxl.load_workbook(filename) #加载一个已存在的Excel文件,并返回一个工作簿对象
c、保存工作簿
python
workbook.save(filename) # 将工作簿保存到指定的文件名。
2、工作表
a、获取工作表
python
workbook.active # 获取当前活动的工作表
workbook[sheetname] # 通过工作表名称获取工作表对象
workbook.sheetnames # 获取工作簿中所有工作表的名称列表
b、创建和删除工作表
python
workbook.create_sheet(title=None, index=None) # 创建一个新的工作表,可以指定工作表的名称和位置。
workbook.remove(worksheet) # 删除指定的工作表。
c、工作表属性设置
python
worksheet.title # 获取或设置工作表的名称。
worksheet.max_row # 获取工作表中的最大有效行数。
worksheet.max_column # 获取工作表中的最大有效列数。
3、单元格
a、获取单元格
python
worksheet['A1']="你好" # 获取单元格并设置值
b、合并单元格
python
worksheet.merge_cells("A1:D1") # 合并A1和D1单元格
C、设置单元格样式
python
cell.font =Font(name='Arial', size=12, bold=True, italic=False, color="FF0000") # 设置字体样式字体样式,红色粗体Arial字体
cell.fill = PatternFill(start_color="FFFF00", end_color="FFFF00", fill_type="solid") # 设置填充样式,黄色填充
cell.alignment = Alignment(horizontal='center', vertical='center') # 设置对齐方式
三、django集成openpyxl库
python
class TestView(APIView):
def get(self,request):
house=HouseInfo.objects.all()
wb = Workbook()
ws = wb.active
ws.title = "Sheet1"
ws.merge_cells('A1:D1') # 合并单元格
ws['A1']='英雄联盟' # 给单元格设置值
ws['A1'].alignment = Alignment(horizontal="center", vertical="center")
ws['A1'].font=Font(bold=True,size=14) # 设置字体大小
ws['A1'].fill =PatternFill(fill_type='solid', start_color='cccccc') # 设置单元格填充颜色
headers = ['city', 'title', 'region', 'area'] # 假设你的模型有这些字段
ws.append(headers) # 添加表头
for obj in house:
row = [obj.city, obj.title, obj.region, obj.area]
ws.append(row) # 将数据库数据写入Excel
response = HttpResponse(content_type='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')
response['Content-Disposition'] = 'attachment; filename="data.xlsx"'
wb.save(response)
return response
再用postman请求这个接口就可以下载这个excel文件了