from django.http import HttpResponse
from openpyxl import Workbook
class ExportExcelMixin:
'''
通用导出 Excel 文件动作
'''
def export_as_excel(self, request, queryset):
'''
导出为 excel 文件. 文件名为 app名.模型类名.xlsx.
:param request:
:param queryset:
:return:
'''
# 用于定义文件名, 格式为: app名.模型类名
meta = self.model._meta
# 模型所有字段名
field_names = [field.name for field in meta.fields]
field_verbose_names = [field.verbose_name for field in meta.fields]
# 定义响应内容类型
response = HttpResponse(content_type='application/msexcel')
# 定义响应数据格式
response['Content-Disposition'] = f'attachment; filename={meta}.xlsx'
wb = Workbook()
ws = wb.active
ws.append(field_verbose_names)
# 遍历选择的对象列表
for obj in queryset:
# 将模型属性值的文本格式组成列表
data = []
for field in field_names:
if hasattr(obj, f'get_{field}_display'):
# 可选属性取显示的值
value = getattr(obj, f'get_{field}_display')()
else:
value = getattr(obj, field)
data.append(f'{value}')
ws.append(data)
# 将数据存入响应内容
wb.save(response)
return response
# 该动作在 admin 中的显示文字
export_as_excel.short_description = '导出Excel'
基于Django 后台导出Execl
最新推荐文章于 2024-08-30 09:36:05 发布
介绍了一个通用的Excel导出功能实现方法,通过Python Django框架下的一个混入类提供批量导出模型实例到Excel文件的能力。该功能支持从模型中获取字段名称及对应的描述,并能够处理模型中的选项字段。
2082

被折叠的 条评论
为什么被折叠?



