Django-rest-framework(DRF)怎么实现Excel文件导出

目录

一、安装openpyxl库

二、openpyxl库介绍

1、工作簿

a、创建工作簿

b、加载工作簿

c、保存工作簿

2、工作表

a、获取工作表

b、创建和删除工作表

c、工作表属性设置

3、单元格

a、获取单元格

b、合并单元格

C、设置单元格样式

三、django集成openpyxl库


一、安装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文件了

相关推荐
程序员岳焱25 分钟前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
计算机毕设定制辅导-无忧学长1 小时前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
麦兜*1 小时前
Spring Boot启动优化7板斧(延迟初始化、组件扫描精准打击、JVM参数调优):砍掉70%启动时间的魔鬼实践
java·jvm·spring boot·后端·spring·spring cloud·系统架构
大只鹅1 小时前
解决 Spring Boot 对 Elasticsearch 字段没有小驼峰映射的问题
spring boot·后端·elasticsearch
ai小鬼头1 小时前
AIStarter如何快速部署Stable Diffusion?**新手也能轻松上手的AI绘图
前端·后端·github
小赖同学啊1 小时前
物联网数据安全区块链服务
开发语言·python·区块链
程序员柳1 小时前
基于微信小程序的校园二手交易平台、微信小程序校园二手商城源代码+数据库+使用说明,layui+微信小程序+Spring Boot
数据库·微信小程序·layui
码荼2 小时前
学习开发之hashmap
java·python·学习·哈希算法·个人开发·小白学开发·不花钱不花时间crud
梦在深巷、2 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb
IT乌鸦坐飞机2 小时前
ansible部署数据库服务随机启动并创建用户和设置用户有完全权限
数据库·ansible·centos7