这里主要是讲序列化单表的几种方法

先看下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种方法的介绍的更多相关文章

  1. Django扩展Auth-User表的几种方法

    方式1, OneToOneField from django.contrib.auth.models import Userclass UserProfile(models.Model): user ...

  2. form表单提交的几种方法

    form表单提交的几种方法 <form id="myform" name="myform" method="post" onsubmi ...

  3. HTML5中表单验证的8种方法

    HTML5中表单验证的8种方法 2012-4-21 11:00| 发布者: benben| 查看: 2765| 评论: 0 摘要: 前一篇,我们介绍了HTML5中新的表单特性和函数, 今天就继续来谈谈 ...

  4. 巨蟒python全栈开发django6: FBV&CBV&&单表查询的其他方法

    练习CBV用法 截图中的action="/cbv/",应该是这样 上边红图,说明mysql有问题,需要重启一下 返回,输入的内容 @wrapper==>cbv=wrapper ...

  5. MySQL数据库分表的3种方法

    原文地址:MySQL数据库分表的3种方法作者:dreamboycx 一,先说一下为什么要分表 当一张的数据达到几百万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目 ...

  6. js阻止表单提交的两种方法

    下面直接看代码. <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  7. ace+validate表单验证(两种方法)

    //修改密码(直接在validate中验证提交) $("#changePassword").on(ace.click_event, function() { var html = ...

  8. HTML5中表单验证的8种方法(转)

    在深人探讨表单验证之前,让我们先思考一下表单验证的真实含义.就其核心而言,表单验证是一套系统,它为终端用户检测无效的控件数据并标记这些错误.换言之,表单验证就是在表单提交服务器前对其进行一系列的检查并 ...

  9. django之单表操作

    1.查询方法: <1> all(): 查询所有结果 <2> filter(**kwargs): 它包含了与所给筛选条件相匹配的对象 <3> get(**kwargs ...

随机推荐

  1. confusing c++ 重写 与 重定义 记录1

    class parent { public: void f() { cout << "parent f()" << endl; } void f(int i ...

  2. 算法练习,链表二分最大n个

    import java.util.ArrayList; import java.util.Collections; import java.util.HashSet; public class Bin ...

  3. angular的启动原理

    当你用浏览器去访问index.html的时候,浏览器依次做了如下一些事情: 加载html,然后解析成DOM: 加载angular.js脚本:加载完成后自执行,生成全局angular对象,监听DOMCo ...

  4. sass实战演练01 - 外部文件引用和变量

    SASS是什么? 目前前端开发中css已经是公认的”前端程序员必须掌握”的知识,最早的css编写都是手工一条条写出来的,工作量大.不利于维护. 而sass的存在使得css开发可以像写代码一样最终生成一 ...

  5. MySQL 服务无法启动

    拷贝的mysql数据库配置文件的路径网络更改

  6. tensorflow降低版本

    tensorflow降低版本: pip install tensorflow==1.2.0 查看版本: import tensorflow as tf print(tf.__version__)

  7. LDA线性判别分析(转)

    线性判别分析LDA详解 1 Linear Discriminant Analysis    相较于FLD(Fisher Linear Decriminant),LDA假设:1.样本数据服从正态分布,2 ...

  8. 2018面向对象程序设计(Java)第1周学习指导及要求

    2018面向对象程序设计(Java) 第1周学习指导及要求(2018.8.24-2018.9.2)   学习目标 了解课程上课方式及老师教学要求,掌握课程学习必要的软件工具: 简单了解Java特点及历 ...

  9. CentOS上开启MySQL远程访问权限

    在CentOS上安装完MySQL后,默认不开始远程访问控制.可以进行如下设定开启. 登录MySQL: mysql -uroot -p 如需修改密码,第一次: mysqladmin -u root pa ...

  10. DRDS SQL兼容性

    SQL 兼容性 更新时间:2017-06-07 13:26:11     DRDS 高度兼容 MySQL 协议和语法,但由于分布式数据库和单机数据库存在较大的架构差异,存在 SQL 使用限制.相关兼容 ...