关于Django中,实现序列化的几种不同方法
前言
关于序列化操作,就是将一个可迭代的数据结构,通过便利的方式进行我们所需要的操作。
今天历来归纳一下,Django中的几种不同得分方法,已经Django-restframework提供的方法
创建一个Django的项目
再新建一个app
创建一个模型,以书本出版社为例,自行迁移完成以后,再配置路由,主要讲解的是views.py,其他的不多说了。
# RESFUL_DJ/app/models.py from django.db import models# Create your models here. class Publisher(models.Model):name = models.CharField(max_length=32, verbose_name='名称', unique=True)address = models.CharField(max_length=128, verbose_name='地址')def __str__(self):return self.nameclass Meta:db_table = 'db_publisher'verbose_name = "出版商"verbose_name_plural = verbose_name
数据库中的内容(使用的是sqlite3)
现在我们来展示数据库中的所有数据,以json的格式传给前端
RESTFUL_DJ/app/views.py
方法一:
from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通过不同的方法,展示所有的出版社对象:param request: 请求:return: 出版社对象'''queryset = models.Publisher.objects.all()# 方法一data = []# 这个方法的缺点就是:# 如果字段多了的话,就需要一个一个去写,会很麻烦# 返回的是字典类型,所以需要json转换成json格式字符串for i in queryset:p_tmp = {"name": i.name,"address": i.address}data.append(p_tmp)import jsonreturn HttpResponse(json.dumps(data), content_type='application/json')
结果:
这是谷歌浏览器安装的插件的原因,方便查看,原结构是这样:
方法二:
from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通过不同的方法,展示所有的出版社对象:param request: 请求:return: 出版社对象'''queryset = models.Publisher.objects.all()# 方法二data = []# django自带的模型转字典方法# 缺点就是图片之类的文件无法转换# 返回的是字典类型,所以需要json转换成json格式字符串from django.forms.models import model_to_dictfor i in queryset:data.append(model_to_dict(i))import jsonreturn HttpResponse(json.dumps(data), content_type='application/json')
结果:
方法三:
from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通过不同的方法,展示所有的出版社对象:param request: 请求:return: 出版社对象'''queryset = models.Publisher.objects.all()# 方法三# 导入django自带的序列化器# # 返回的是json字符串,不需要再用json转换一次了from django.core import serializersdata = serializers.serialize('json', queryset)return HttpResponse(data, content_type='application/json')
结果:
方法四:
首先需要安装djangorestframework(pip install djangorestframework)
配置好settings.py文件
在app下新建文件serializers.py,(使用跟form差不多)
from rest_framework import serializers from app import modelsclass PublisherSerializer(serializers.Serializer): # 类的命名必须是models中的模型名称加Seriaizerid = serializers.IntegerField(read_only=True)name = serializers.CharField(max_length=32)address = serializers.CharField(max_length=128)def create(self, validated_data):'''重写create方法,创建数据:param validated_data: 用户传递的,经过了校验的数据:return: 创建的数据'''return models.Publisher.objects.create(**validated_data)def update(self, instance, validated_data):'''更新数据操作:param instance: 原来的数据:param validated_data: 用户传递的,经过了校验的数据:return: 更新后的数据'''instance.name = validated_data.get('name', instance.name)instance.address = validated_data.get('address', instance.address)instance.save()return instance
在shell中,测试一下展示操作
测试一下create共功能:
运行项目,结果:
from django.shortcuts import render from django.http import HttpResponsefrom app import modelsdef publisher_list(request):'''通过不同的方法,展示所有的出版社对象:param request: 请求:return: 出版社对象'''queryset = models.Publisher.objects.all()# 方法四# 使用djangorestframework中的序列化from app import serializersserializer = serializers.PublisherSerializer(queryset, many=True) # 多个遍历data = serializer.data # OrderedDict对象import jsonreturn HttpResponse(json.dumps(data), content_type='application/json')
在前面创建的serializers.py文件中定义的序列化字段,其实和models中的模型字段是一样的,我们可以继承过来使用
继承serializers.ModelSerializer方法,里面本身就封装好了新建更新等数据操作的方法
更改serializers.py文件的内容:
from rest_framework import serializers from app import modelsclass PublisherSerializer(serializers.ModelSerializer):class Meta:model = models.Publisherfields = ('id','name','address')
结果:
还是没有问题,可以使用的。
转载于:https://www.cnblogs.com/pywjh/p/10847085.html
关于Django中,实现序列化的几种不同方法相关推荐
- Django中Model继承的三种方式
Django中Model继承的三种方式 Django中Model的继承有三种: 1.抽象继承 2.多表继承 3.proxy model(代理model) 1.抽象继承 第一种抽象继承,创建一个通用父类 ...
- django 中实现文件下载的3种方式
方法一:使用HttpResponse from django.shortcuts import HttpResponse def file_down(request): file=open('/hom ...
- django中验证码图片的两种使用方法
@[T 提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 学习的时候参考过很多篇他人的博客,本篇博客是我第一篇学习笔记 一.方法一使用步骤 1.下载库 2.setting中的 ...
- Django 缓存、序列化、信号
一,缓存 由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用:缓存,缓存将一个某个views的返回值保存至内存或者memcac ...
- java 复制文件_Java中复制文件的4种方法
Java拷贝文件是一种非常常见的操作.但是java.io.File类没有任何快捷方法可以将文件从源复制到目标文件.在这里,我们将了解学习可以在java中复制文件的四种不同方法. 方法一:使用Strea ...
- Django:序列化的几种方法
前言 关于序列化操作,就是将一个可迭代的数据结构,通过便利的方式进行我们所需要的操作. 今天历来归纳一下,Django中的几种不同得分方法,已经Django-restframework提供的方法 创建 ...
- 谈谈Django REST Framework(DRF)中的序列化器
摘要 Django REST Framework(DRF)是一个强大的工具,可以帮助我们构建和处理RESTful API.其中的序列化器(Serializers)是其核心组件之一,它允许我们快速有效地 ...
- Django中提供的6种缓存方式
由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用: 缓存,缓存将一个某个views的返回值保存至内存或者memcache中, ...
- django中序列化、反序列化过程
一.定义序列化器 a.如果需要使用DRF框架来实现序列化.反序列化.数据库操作,在子应用中创建serializers.py文件 b.文件名推荐命名为serializers.py 在serializer ...
最新文章
- Facebook 开源了一整套重要的 Linux 内核组件与工具!
- 记一次 解决 vue 兼容ie11 的问题
- 佛山市禅城区计算机培训机构排名前十,佛山名气大的机器人编程教育品牌排名...
- python与c语言在语法上的区别-python和c语言的区别是什么
- Python with open() as 读写文件
- QQ消息支持HTML吗,WebQQ全面升级支持IE9 HTML5无处不在
- 青岛计算机学校分数线,青岛计算机应用与维修专业职业学校收费标准,物联网应用技术中专学校分数线...
- mybatis mysql 配置文件_mybatis简单应用(基于配置文件)_MySQL
- html5的q标签,HTML 5 q 标签 - HTML 参考手册
- opencv注释中的@brief、@code/@endcode、@param、@sa 以及 如何在pycharm中看到opencv函数的完整注释
- 五到十分钟java演讲_10分钟励志演讲稿5篇最新
- 平均查找长度 (ASL)
- java之家_java之家
- [转]NLP关键词提取方法总结及实现
- 大数据平台的作用有什么
- 计算机学报在线阅读,含指针程序的单子切片方法-计算机学报.pdf
- JQuery序列化和反序列化
- 计算机历史博物馆观后感:阿达·洛芙莱斯生平1
- Promise 对象 异步 then 回调函数
- 你竟然写出这样的代码