可以使用ModelSerializer根据模型类生成字段
前言
ModelSerializer的作用:
- 1.可以参考模型类自动生成字段, 还可以自己编写字段
- 2.提供了create方法,update方法
一、定义模型类序列化器
from rest_framework import serializers
from . import models
from .models import City_cropinfo, User
#定义用户模型类序列化器
class UserModelSerializer(serializers.ModelSerializer):
class Meta:
model = User #参考模型类生成字段
fields = '__all__' #生成所有字段
二、测试序列化与反序列化
1.序列化
使用模型类序列化器, 测试序列化
- 操作流程
from agriculture.models import User
from agriculture.serializers import UserModelSerializer
# 1,获取模型类对象
user = User.objects.get(id=1)
# 2,创建序列化器对象
serializer = UserModelSerializer(instance=user)
# 3,输出结果
serializer.data
- 输出结果
输出结果如下:
{'id': 1, 'useraccount': '123456', 'password': '123', 'username': '你好', 'phone': '13232345678', 'email': '123456@qq.com'}
2.反序列化入库操作
使用模型类序列化器, 测试反序列化的入库操作
- 操作流程
from agriculture.serializers import UserModelSerializer
# 1,准备字典数据
user_dict = {
'useraccount': '000001',
'password': 'abc123',
'username': '旺旺',
'phone': '13567812333',
'email':'12345601@qq.com'
}
# 2,序列化器对象创建
serializer = UserModelSerializer(data=user_dict)
# 3,校验,入库
serializer.is_valid(raise_exception=True)
serializer.save()
- 测试结果
已将将数据加入了数据库
3.反序列化更新操作
使用模型类序列化器, 测试反序列化的更新操作
- 操作流程
from agriculture.models import User
from agriculture.serializers import UserModelSerializer
# 1,准备字典数据, 用户对象
user = User.objects.get(id=4)
user_dict = {
'useraccount': '000001',
'password': 'abcd1234',
'username': '财财',
'phone': '13567812666',
'email':'12345602@163.com'
}
# 2,序列化器对象创建
serializer = UserModelSerializer(instance=user, data=user_dict)
# 3,校验,入库
serializer.is_valid(raise_exception=True)
serializer.save()
- 测试结果
已经修改了数据库中的数据
总结
ModelSerializer比起普通的序列化器方便快捷了很多