django序列化单表的4种方法的介绍
这里主要是讲序列化单表的几种方法
先看下models中设计的表结构
from django.db import models # Create your models here. class Book(models.Model):
id = models.AutoField(primary_key=True)
book_name = models.CharField(max_length=64,null=False,blank=False,verbose_name="书籍名称")
book_price = models.DecimalField(max_digits=5,decimal_places=2,null=False,blank=False,verbose_name="书籍价格")
book_publish = models.ForeignKey(to="Publish",to_field="id",verbose_name="书籍出版社")
book_auther = models.ManyToManyField(to="Auther",verbose_name="书籍作者") class Meta:
verbose_name = "书籍表"
verbose_name_plural = verbose_name
def __str__(self):
return self.book_name class Publish(models.Model):
id = models.AutoField(primary_key=True)
publish_name = models.CharField(max_length=64,null=False,blank=False) class Meta:
verbose_name = "出版社表"
verbose_name_plural = verbose_name def __str__(self):
return self.publish_name class Auther(models.Model):
id = models.AutoField(primary_key=True)
auther_name = models.CharField(max_length=64,null=False,blank=False)
def __str__(self):
return self.auther_name class Meta:
verbose_name = "作者表"
verbose_name_plural = verbose_name
我们只对出版社表进行序列化,因为在我们这里的事例中,出版社表所有的字段都是单表字段,处理起来比较简单,后面我们就会介绍一对多和多对多字段的表该如何序列化
我们这里使用cbv的方式来测试
from django import views
下面先介绍三种序列化的方式
import json
class test_cbv(views.View):
def get(self,request,*args,**kwargs): # 一、序列化 publish_list = models.Publish.objects.all()
publish_obj = models.Publish.objects.all().first() # 方式1
# ser1 = publish_list.values("id","publish_name")
# ret1 = json.dumps(list(ser1))
# return HttpResponse(ret1) # 2、方式二
# from django.forms.models import model_to_dict
# model_to_dict 把一个model对象转换为字典的方法
# ret2 = []
# for obj in publish_list:
# temp.append(model_to_dict(obj))
# return HttpResponse(json.dumps(ret2)) # 3、方式3
# from django.core import serializers
# serializers ---django的序列化组件 # ret3 = serializers.serialize(format="json",queryset=publish_list)
# 指明格式为json,传递一个queryset对象进去就可以了 # return HttpResponse(ret3)
最后我们看下restframework序列化的方式,可以序列化一个queryset对象,也可以序列化一个model对象
首先需要通过pip安装restframworkork
pip install djangorestframework
然后按照下面的格式写一个类
# 为queryset或者model对象做序列化的类
from rest_framework import serializers
class pub_serializers(serializers.Serializer):
publish_name = serializers.CharField()
指明对表中哪些字段做处理,和django的froms组件很像
# 4、方式4
# ps_queryset = pub_serializers(publish_list,many=True)
# return HttpResponse(ps_queryset.data) ps_model = pub_serializers(publish_obj)
print(ps_model.data)
return HttpResponse(ps_model.data)
至此,单表的序列化我们介绍完了!
django序列化单表的4种方法的介绍的更多相关文章
- Django扩展Auth-User表的几种方法
		
方式1, OneToOneField from django.contrib.auth.models import Userclass UserProfile(models.Model): user ...
 - form表单提交的几种方法
		
form表单提交的几种方法 <form id="myform" name="myform" method="post" onsubmi ...
 - HTML5中表单验证的8种方法
		
HTML5中表单验证的8种方法 2012-4-21 11:00| 发布者: benben| 查看: 2765| 评论: 0 摘要: 前一篇,我们介绍了HTML5中新的表单特性和函数, 今天就继续来谈谈 ...
 - 巨蟒python全栈开发django6: FBV&CBV&&单表查询的其他方法
		
练习CBV用法 截图中的action="/cbv/",应该是这样 上边红图,说明mysql有问题,需要重启一下 返回,输入的内容 @wrapper==>cbv=wrapper ...
 - MySQL数据库分表的3种方法
		
原文地址:MySQL数据库分表的3种方法作者:dreamboycx 一,先说一下为什么要分表 当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目 ...
 - js阻止表单提交的两种方法
		
下面直接看代码. <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...
 - ace+validate表单验证(两种方法)
		
//修改密码(直接在validate中验证提交) $("#changePassword").on(ace.click_event, function() { var html = ...
 - HTML5中表单验证的8种方法(转)
		
在深人探讨表单验证之前,让我们先思考一下表单验证的真实含义.就其核心而言,表单验证是一套系统,它为终端用户检测无效的控件数据并标记这些错误.换言之,表单验证就是在表单提交服务器前对其进行一系列的检查并 ...
 - django之单表操作
		
1.查询方法: <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs ...
 
随机推荐
- vector 内存释放相关
			
在使用vector 存储char 类型时 new的数据 在vecto 执行rerase的时候或者 单项执行clear 内存是不能被释放的. 比如有下面的一个测试: class SnapshotInfo ...
 - python流程控制while和if
			
流程控制 1.流程控制if if的4种语法 语法1: #结构形式 #if条件: # 代码1 # 代码2 # 代码3 # ... key_bak=123 key=int(input('key:')) ...
 - Linux学习笔记--vim
			
Vim是从 vi 发展出来的一个文本编辑器.代码补完.编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用. vim的三种模式 命令模式(Command mode),输入模式(Insert m ...
 - 二叉堆复习(包括d堆)
			
要期中考了……我真的是什么也不会啊,书都没看过TAT. 好吧整理一下二叉堆,这里就以最大堆为例好了. 首先二叉堆其实是一棵CBT,满足父节点的键值大于左右子节点的键值(wikipedia把这个叫键值, ...
 - Mysql数据库如何创建用户
			
创建test用户,密码是1234. MySQL u root -p CREATE USER 'test'@'localhost' IDENTIFIED BY '1234'; #本地登录 CREATE ...
 - mongodb的优缺点
			
在这里收集下我自己对Mongodb的一些优缺点方面的认识,或者是通过其它比较可靠的网文上引用或者摘录的作为依据,这个是一个渐进的过程,也是随着我对Mongodb认识的加深而不断扩展的. (1)Mong ...
 - Hibernate 再接触  基础配置 搭建Log4j环境 Junit日志环境等
			
<!-- Drop and re-create the database schema on startup --> <property name="hbm2ddl.aut ...
 - 吴裕雄 oracle PL/SQL编程
 - 局部变量and全局变量
			
局部变量 <1>什么是局部变量 如下图所示: <2>小总结 局部变量,就是在函数内部定义的变量 不同的函数,可以定义相同的名字的局部变量,但是各用个的不会产生影响 局部变量的作 ...
 - TensorFlow saved_model 模块
			
最近在学tensorflow serving 模块,一直对接口不了解,后面看到这个文章就豁然开朗了, 主要的困难在于 tf.saved_model.builder.SavedModelBuilde ...