$Django Rest Framework-序列化组件
1 序列化组件
e=serializers.SerializerMethodField()
# 方法名:叫get_字段名, 参数,返回字典
def get_e(self,obj): #obj为book对象
from app01 import models
from rest_framework import serializers
from rest_framework.serializers import Serializer,ModelSerializer
from django.http import JsonResponse class auth(Serializer):
name=serializers.CharField()
age=serializers.CharField()
#方式1
class ser(Serializer): #*****如果不指定source,字段必须对应起来,如果指定了source,字段可以任意命名
a=serializers.CharField(source='name') #source 可以指定字段,也可也指定方法
b=serializers.CharField(source='authors')
c=serializers.CharField(source='publish.name')
d=serializers.CharField(source='publish.test')
e=serializers.SerializerMethodField()
# 方法名:叫get_字段名,要传参数,参数是:当前book对象
def get_e(self,obj): #obj为book对象
# for循环
# li=[{'name':i.name,'age':i.age} for i in obj.authors.all()]
# return li
#序列化
auths=obj.authors.all()
li=auth(auths,many=True)
return li.data
#方式2
class ser1(ModelSerializer):
class Meta:
model=models.Book
fields='__all__'
# fields=['name','price']
# exclude=['authors']
depth=10 #深度为1 当前模型字段 为2跨1个表的字段
#cbv视图
class show(APIView):
def get(self,request):
#drf
books=models.Book.objects.all()
bb=ser1(instance=books,many=True) #queryset对象/也可以是多单个对象|||many指定单个多个
print(bb.data) #json格式dic
return JsonResponse(bb.data,safe=False)
#django自带的
# from django.core import serializers
# books=models.Book.objects.all()
# ret=serializers.serialize('json',books)
# print(ret,type(ret)) #json格式str
# dic = {'data': ret}
# return HttpResponse(ret)
Serializer与ModelSerializer
2 序列化组件
①前台url请求数据:
HyperlinkedIdentityField 返回一个数据带链接 写在继承Serializer的类中(很少用)
*3个参数以及scontext={'request':request} #拼了一条路由
class Ser_link(Serializer):
name=serializers.CharField(max_length=32,error_messages={'max_length':'最长32位'})
#get请求时Ser_link(books,many=True,context={'request':request}) 域名
#参1:路由别名 参2:字段 参3:有名分组名
publish = serializers.HyperlinkedIdentityField (view_name='aaa', lookup_field='publish_id', lookup_url_kwarg='id')
class Books(APIView):
def get(self,request):
books=models.Book.objects.all()
ser=Ser_link(books,many=True,context={'request':request})
return JsonResponse(ser.data,safe=False)
get请求返回数据带连接(视图,组件)
url(r'^books/$', views.Books.as_view()), url(r'^publish/(?P<id>\d+)$', views.Publish.as_view(),name='aaa')
#http://127.0.0.1/publish/1
路由
②前台传数据到后台:
0直接调save()保存更新的话,(必须继承ModelSerializer)
1.数据校验(与form组件类似有error_messages,局部钩子等) 2.数据保存/更新(传instance和不传instance的区别# 不传instance,调save(),往数据库新增数据# 传instance,调save(),修改数据,)
class BookSerializer(serializers.ModelSerializer):
class Meta:
model = models.Book
fields = '__all__' name = serializers.CharField(min_length=2, error_messages={'required': '该字段必填'})
authors = serializers.CharField(required=False) # 局部钩子:
def validate_name(self, value):
# print(value)
if value.startswith('sb'):
# 不能以sb开头
raise ValidationError('不能以sb开头')
else:
return value # 全局钩子找到了
def validate(self, value):
# value是所有校验通过数据的字典
print(value)
name = value.get('name')
price = value.get('price')
if name and price:
if str(name) == str(price):
return value
else:
raise ValidationError('名字跟价格不相等')
return value class BooksDetail(APIView):
authentication_classes = [Auth, ] def get(self, request, pk):
response = {'status': 100, 'msg': '成功'}
ret = models.Book.objects.all().filter(pk=pk).first()
# 生成一个序列化的对象,传参数
# 序列化单,记住many=False
if ret:
book_ser = BookSerializer(ret, many=False)
print(book_ser.data)
response['data'] = book_ser.data
else:
response['status'] = 101
response['msg'] = '您查询的不存在' return JsonResponse(response, safe=False) def put(self, request, pk):
response = {'status': 100, 'msg': '成功'}
ret = models.Book.objects.all().filter(pk=pk).first()
if ret:
# 数据校验
# 传instance和不传instance,传instance的区别
# 不传instance,调save(),往数据库新增数据
# 传instance,调save(),修改数据
ser = BookSerializer(data=request.data, instance=ret)
if ser.is_valid():
# ret.name=request.data.get('name')
ser.save()
else:
response['status'] = 101
response['msg'] = ser.errors
else:
response['status'] = 102
response['msg'] = '修改的对象不存在'
return JsonResponse(response, safe=False)
url(r'^books/(?P<pk>\d+)$', views.Books_xx.as_view()),
路由
随机推荐
- 能使 Oracle 索引失效的六大限制条件【转】
. 引用自: http://www.cnblogs.com/orientsun/archive/2012/07/05/2577351.html 总结得非常到位 Oracle 索引的目标是避免全表扫描 ...
- 【1】【leetcode-77】 组合
(典型,做过似曾相识但不熟悉,基本知道怎么做但调试了一个多小时各种错) 给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合. 示例: 输入: n = 4, k = 2 输出: ...
- ArcGis Python脚本——ArcGIS 中使用的 Python 是什么版本
Python 编程语言用于自 9.0 起的各版本 ArcGIS 中,并被整合到 ArcMap 和 ArcGIS for Server 的自动安装中. ArcGIS 将在完整安装过程中安装下列 Pyth ...
- 细说log4j之概述
log4j官网:https://logging.apache.org/ log4j目前存在2个版本:log4j 1.x 和log4j 2.x,目前官方主推2.x版本(log4j 1.x已于2015.0 ...
- 对空间数据(Shape)重新排序
打开ArcToolBox,数据管理工具->常规(General)->排序
- Java8新特性_接口中的默认方法
默认方法由来猜想 1. Collection接口.Collections公共类. 同是操作集合,为啥要搞俩?没必要.在接口中搞一些默认实现,一个接口即搞定了. 2. Java8支持Lambda表达式 ...
- [译]C#7 Pattern Matching
原文 public struct Square { public double Side { get; } public Square(double side) { Side = side; } } ...
- 【bzoj 3173】[Tjoi2013]最长上升子序列
Description 给定一个序列,初始为空.现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上升子序列长度是多少? Input 第一行一 ...
- EF 事物Transaction简单操作
/// <summary> /// 申请提现 /// </summary> /// <param name="userId">用户id</ ...
- Leetcode#169. Majority Element(求众数)
题目描述 给定一个大小为 n 的数组,找到其中的众数.众数是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素. 你可以假设数组是非空的,并且给定的数组总是存在众数. 示例 1: 输入: [3,2,3] ...