3、DjangoAdmin导出excel和csv文件

一、导出Excel

1、安装openpyxl库

2、admin文件

# 导入openpyxl库中的Workbook类,用于创建Excel文件  
from openpyxl import Workbook  
# 导入Django的admin模块,用于在Django admin后台注册和管理模型  
from django.contrib import admin  
# 导入HttpResponse类,用于生成HTTP响应  
from django.http import HttpResponse  
# 假设这是从某个应用的models.py文件中导入的PrettyNum模型  
from .models import Category  

# 定义一个名为ExportExcelMixin的混合类(Mixin),用于添加导出Excel的功能  
class ExportExcelMixin(object):  
    # 定义一个方法export_as_excel,用于将查询集(queryset)导出为Excel文件  
    def export_as_excel(self, request, queryset):  
        # 获取当前模型的元数据对象  
        meta = self.model._meta  
        # 从元数据对象中提取所有字段的名称  
        field_names = [field.name for field in meta.fields]  
      
        # 创建一个HttpResponse对象,设置内容类型为Excel文件  
        response = HttpResponse(content_type='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')  
        # 设置响应的Content-Disposition头部,指定文件名为模型名加.xlsx后缀  
        response['Content-Disposition'] = f'attachment; filename={meta.model_name}.xlsx'  
      
        # 创建一个Workbook对象,即一个Excel工作簿  
        wb = Workbook()  
        # 激活工作簿中的第一个工作表  
        ws = wb.active  
        # 将字段名称作为第一行写入工作表  
        ws.append(field_names)  
      
        # 遍历查询集中的每个对象  
        for obj in queryset:  
            # 对于每个对象,提取其字段值,并将它们作为一行数据写入工作表  
            row_data = [getattr(obj, field) for field in field_names]  
            ws.append(row_data)  
      
        # 将工作簿保存到HttpResponse对象中,以便作为文件下载  
        wb.save(response)  
        # 返回包含Excel文件的HttpResponse对象  
        return response  
  
    # 为export_as_excel方法设置简短描述,以便在Django admin后台显示  
    export_as_excel.short_description = '导出Excel'  


# 使用admin.register装饰器注册PrettyNum模型到Django admin后台  
# 同时,通过继承ExportExcelMixin混合类,为PrettyNumAdmin类添加导出Excel的功能  
@admin.register(Category)  
class PrettyNumAdmin(admin.ModelAdmin, ExportExcelMixin):  
    # 定义在Django admin后台表单中显示的字段  
    fields = ('name', )  
  
    # 定义在Django admin后台列表视图中显示的字段  
    list_display = ('name', )  
  
    # 定义在Django admin后台列表视图中可用的过滤器  
    list_filter = ('name', )   
  
    # 定义在Django admin后台搜索栏中可搜索的字段  
    search_fields = ('name', )   
  
    # 将export_as_excel方法添加到actions列表中,以便在Django admin后台作为操作选项显示  
    actions = ['export_as_excel']

ExportExcelMixin类为excel的导出类可直接复制,带装饰器的类,修改类参数,修改字段。

二、导出csv

导出类似,与导出excel代码合并如下

from django.contrib import admin  
from django.http import HttpResponse  
from django.urls import reverse  
from urllib.parse import quote  
from openpyxl import Workbook  
import csv  
from .models import Category  
  
class ExportExcelMixin:  
    def export_as_excel(self, request, queryset):  
        # 获取当前模型的元数据对象  
        meta = self.model._meta  
        # 从元数据对象中提取所有字段的名称  
        field_names = [field.name for field in meta.fields]  
      
        # 创建一个HttpResponse对象,设置内容类型为Excel文件  
        response = HttpResponse(content_type='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet')  
        # 设置响应的Content-Disposition头部,指定文件名为模型名加.xlsx后缀  
        response['Content-Disposition'] = f'attachment; filename={meta.model_name}.xlsx'  
      
        # 创建一个Workbook对象,即一个Excel工作簿  
        wb = Workbook()  
        # 激活工作簿中的第一个工作表  
        ws = wb.active  
        # 将字段名称作为第一行写入工作表  
        ws.append(field_names)  
      
        # 遍历查询集中的每个对象  
        for obj in queryset:  
            # 对于每个对象,提取其字段值,并将它们作为一行数据写入工作表  
            row_data = [getattr(obj, field) for field in field_names]  
            ws.append(row_data)  
      
        # 将工作簿保存到HttpResponse对象中,以便作为文件下载  
        wb.save(response)  
        # 返回包含Excel文件的HttpResponse对象  
        return response  
  
    export_as_excel.short_description = '导出Excel'  
  
class ExportCsvMixin:  
    def export_as_csv(self, request, queryset):  
        meta = self.model._meta  
        field_names = [field.name for field in meta.fields]  
  
        filename = f"{meta.verbose_name_plural}.csv"  
        filename_quoted = quote(filename)  
  
        response = HttpResponse(content_type='text/csv; charset=utf-8')  
        response['Content-Disposition'] = f'attachment; filename="{filename_quoted}"'  
  
        writer = csv.writer(response)  
        writer.writerow(field_names)  
        for obj in queryset:  
            row_data = [getattr(obj, field) for field in field_names]  
            writer.writerow(row_data)  
  
        return response  
  
    export_as_csv.short_description = '导出CSV'  
  
@admin.register(Category)  
class CategoryAdmin(admin.ModelAdmin, ExportExcelMixin, ExportCsvMixin):  
    fields = ('name',)  
    list_display = ('name',)  
    list_filter = ('name',)  
    search_fields = ('name',)  
    actions = ['export_as_excel', 'export_as_csv']  

写导出excel和导出csv文件的两个类,写一个导出字段的类引入以上两个类。

### 批量导入功能的实现 要在 Django Admin 中实现批量导入功能,可以通过 `import_export` 库来简化操作。该库允许管理员通过 CSVExcel 文件的形式上传数据到数据库中。 #### 安装依赖 首先安装 `django-import-export` 库: ```bash pip install django-import-export ``` #### 配置 settings.py 在项目的 `settings.py` 文件中的 `INSTALLED_APPS` 列表里添加 `'import_export'`[^4]: ```python INSTALLED_APPS = [ ... 'import_export', ... ] ``` #### 创建资源类 为了使模型的数据可以被导出或导入,需要为对应的模型创建一个资源类。假设有一个名为 `Product` 的模型: ```python from import_export import resources from .models import Product class ProductResource(resources.ModelResource): class Meta: model = Product fields = ('id', 'name', 'price', 'stock') # 自定义字段列表 export_order = ('id', 'name', 'price', 'stock') ``` #### 修改 admin.py 接着,在应用的 `admin.py` 文件中注册资源类,并启用批量导入/导出功能: ```python from django.contrib import admin from import_export.admin import ImportExportModelAdmin from .models import Product from .resources import ProductResource @admin.register(Product) class ProductAdmin(ImportExportModelAdmin): resource_class = ProductResource ``` 这样配置完成后,进入 Django Admin 页面时会发现新增了一个“导入”按钮,点击即可按照指定格式上传文件完成数据的批量导入[^1]。 #### 数据准备 确保用于导入的文件遵循正确的格式。例如,如果使用的是 CSV 文件,则其列名应与模型字段匹配。下面是一个示例 CSV 文件的内容: ```csv id,name,price,stock 1,T-shirt,20.50,100 2,Jacket,89.99,50 3,Pants,45.75,75 ``` #### 测试导入功能 访问 Django Admin 后台,找到对应的产品管理页面,尝试上传上述样例文件验证功能是否正常工作。 --- ### 注意事项 - **安全性**:由于禁用了 CSRF 中间件可能带来安全风险,因此建议仅在受信任环境中测试此设置。 - **性能优化**:对于大规模数据集考虑分批处理以免内存溢出等问题发生。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值