【django framework】ModelSerializer+GenericAPIView接口数据流

GenericAPIView数据从序列化到最终返回响应的数据流

// 以ModelSerializer+generics.CreateAPIView为例

程序终归是为了处理数据,怎么处理,以怎样的顺序和方法去处理,就涉及到了具体的业务流程。当我们是用了一个牛掰的框架,发现原来熟悉的方法不见了,取而代之的是不断地重写或复用已有的方法,但要想知道什么时候应该去复用谁,什么时候应该去重写谁,就必须要清楚数据在各模块方法间的传递顺序,即数据流。


在这里插入图片描述



1 数据从 Serializer 传递到 generics.CreateAPIView再到最终提交到数据库经历的几个过程

从 Serializer 到 generics.CreateAPIView 再到数据库的数据流包括了数据的反序列化、数据验证、实例创建、持久化、返回响应这几个过程。

1.1 数据反序列化

前端调用接口,给到后端的是JSON/XML结构的数据,这类数据本质是字符串,无法被后端代码直接使用,所以要将字符串变成python对象,这个过程叫做反序列化。反之,则为序列化。
这一步是透明的,通常不需要做处理。

1.2 数据验证(Validation)

一旦数据被反序列化,Serializer 将会对数据进行验证。这意味着它会检查数据是否符合您在 Serializer 类中定义的模型字段的规则,例如字段类型、长度限制、唯一性等等。如果数据验证失败,Serializer 将会抛出验证错误。
这一步可以:

  • 可以用validate方法自定义验证方式,可以校验一些特殊的字段,比如电话号码等等
  • 可以重写Serializer的create方法,从而修改或添加一些必要的字段

1.3 创建实例(Instance Creation)

如果数据通过了验证,generics.CreateAPIView 的 create() 方法将被调用。在该方法内部,会使用验证后的数据创建模型实例。通常,您会使用 serializer.save() 方法来创建模型实例,该方法会返回已经保存到数据库的实例对象。
这一步可以:

  • 可以重写perform_create方法,在正式提交到数据库之前,对一些字段做修改

1.4 数据保存(Data Saving)

perform_create中,会调用serializer.save() 方法来创建模型实例,一旦实例被创建,save() 方法会将实例保存到数据库中。这通常会触发数据库操作,如 INSERT 查询,将数据持久化存储到数据库中。

1.5 返回响应(Response)

数据保存成功后,create() 方法会返回一个 HTTP 响应,通常是成功创建对象的响应,包含新创建的对象的数据。
这一步可以:

  • 可以重写create方法,可以自定义返回值。

2 同时重写perform_create和create方法时

在 generics.CreateAPIView 中,数据首先到达 perform_create() 方法,然后再到达 create() 方法。同时重写了这两个方法,数据流并没有发生变化,这两个方法的作用也没有发生变化。
依然是perform_create用来保存实例到数据库,create则返回响应结果。
可以根据实际情况来重写这两个方法。


  • 17
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要实现导出数据,你需要按照以下步骤进行操作: 1. 安装 pandas 和 django-excel-response 包,可以使用 pip install pandas 和 pip install django-excel-response 命令进行安装。 2. 在 views.py 文件中编写视图函数,用于处理导出数据的请求。在该函数中,你需要使用 pandas 库读取数据,并将其导出为 Excel 文件格式。然后将 Excel 文件返回给用户。这里使用 django-excel-response 包提供的 ExcelResponse 类来实现。 ```python import pandas as pd from django.http import HttpResponse from django_excel_response import ExcelResponse def export_data(request): # 从数据库中获取数据 data = YourModel.objects.all().values() # 转换为 Pandas 数据框 df = pd.DataFrame(list(data)) # 将数据导出为 Excel 文件 output = BytesIO() writer = pd.ExcelWriter(output, engine='xlsxwriter') df.to_excel(writer, index=False, sheet_name='Sheet1') writer.save() output.seek(0) # 返回 Excel 文件 return ExcelResponse(output.getvalue(), content_type='application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', status=200) ``` 3. 在 urls.py 文件中添加对应的 URL 路由,将导出数据的请求映射到视图函数。 ```python from django.urls import path from . import views urlpatterns = [ path('export-data/', views.export_data, name='export_data'), ] ``` 4. 在前端页面上添加一个导出数据的按钮,并使用 AJAX 请求后端视图函数,从而实现导出数据的功能。 ```html <button id="export-btn">导出数据</button> <script> $(document).ready(function() { $('#export-btn').click(function() { $.ajax({ url: '/export-data/', type: 'GET', success: function(response) { // 下载 Excel 文件 var link = document.createElement('a'); link.href = window.URL.createObjectURL(response); link.download = 'data.xlsx'; link.click(); } }); }); }); </script> ``` 这样就可以使用 Django、Layui 和 Pandas 实现导出数据的功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

勇敢牛马 不怕困难

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值