Django高级进阶[DRF](2. 基本操作

2018-11-13  本文已影响0人  錦魚

项目准备工作

1. 新建一个虚拟环境
mkvirtualenv h2_dajngo_drf_envs
2.安装django和djangorestframework
pip install django==1.11
pip install djangorestframework
3. 新建一个Django项目
4. 将rest_framework注册到 INSTALLED_APPS中去(setting.py)
INSTALLED_APPS = (
    ...
    'rest_framework',
)
5. rest_framework相关配置(setting.py)
# 所有跟rest framework有关的配置
REST_FRAMEWORK ={
   'DEFAULT_PERMISSION_CLASSES': ['rest_framework.permissions.IsAdminUser',],
   'PAGE_SIZE': 10
}

序列化

创建表
  • 以出版社的表为例子,例如出版社有名字和所属地区
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.name
class Meta:
    verbose_name = '出版社'
    verbose_name_plural = verbose_name
生成迁移文件和执行迁移
  • 在这里我们暂时用sqlite数据库

    python manage.py makemigrations
    python manage.py migrate
    


序列化

我们把变量从内存中变成可存储或传输的过程称之为序列化


JSON

如果我们要在不同的编程语言之间传递对象,就必须把对象序列化为标准格式
把Python对象变成一个JSON
import json
d = dict(name='Zhangsan', age=26, score=75)
# dumps()方法返回一个str,内容就是标准的JSON
json_str= json.dumps(d)
要把JSON反序列化为Python对象,用loads()方法
json_str = '{"age": 26, "score": 75, "name": "Zhangsan"}'
json.loads(json_str)

通过以下方式可以实现API:

from .models import Publisher
from django.http import HttpResponse
import json

def publisher_list(request):
# 查询出所有的出版社
queryset = Publisher.objects.all()
# 转换成python中的列表
data = []
for i in queryset:
    # 每一个对象都手动转化成一个字典
    p_tmp = {
        'name': i.name,
        'address': i.address
    }
data.append(p_tmp)

return HttpResponse(json.dumps(data), content_type='application/json'
对于以上的方案进行第一次改进:
data = []
from django.forms.models import model_to_dict
    for i in queryset:
        data.append(model_to_dict(i))
对于以上的方案进行第二次改进(使用Django自带的serializers):
data = []
from django.core import serializers
data = serializers.serialize('json', queryset)

import json
    return HttpResponse(data, content_type='application/json')

DRF提供的序列化

在APP下创建一个序列化一个文件
from rest_framework import serializers
# 类名固定为表名称 + Serializer

class PublisherSerializer(serializers.Serializer):
# read_only必须为True,因为我们模型里面的id是一个自增字段,不可写,自动生成
    id = serializers.IntegerField(read_only=True)
    name = serializers.CharField(max_length=32)
    address = serializers.CharField(max_length=128)
使用自己定义的序列化
  • 非常方便的把我们的对象转化成一个字典
from app01 import models,serializers

p1 = models.Publisher.objects.first()# 先找到一个出版社的对象
s = serializers.PublisherSerializer(p1)
s.data
def create(self, validated_data):
# validated_data参数不需要特意去记,就是经过校验的数据
    return  models.Publisher.objects.create(**validated_data)

def update(self, instance, validated_data):
    instance.name = validated_data.get('name', instance.name)
    instance.address = validated_data.get('address', instance.address)
    instance.save()
    return instance
from app01 import models,serializers
p2 = {'name':'图灵出版社','address':'大兴天宫院'}
s = serializers.PublisherSerializer(data=p2)
s.is_valid()# 如果数据检测没有问题
Out[5]: True

s.validated_data # 可以查看类型,观察到这是一个有序字典
Out[6]: OrderedDict([('name', '图灵出版社'), ('address', '大兴天宫院')])

s.save() # 保存到数据库
Out[7]: <Publisher: 图灵出版社>
# 第三次改进
from app01 import serializers
# 如果是多个对象,一定要写many = True,就是说我们是多个对象,
# many=True告诉程序要用遍历的方式去给我们做序列化
s = serializers.PublisherSerializer(queryset, many=True)

import json
return HttpResponse(json.dumps(s.data), content_type='application/json')

改进自定义序列化模块

  • 因为那些字段,我们已经在模型中创建,没有必要再创建一次,所以我们再进行一次改进
class PublisherSerializer(serializers.ModelSerializer):
class Meta:
    model = models.Publisher # 我们要使用的模型
    # 我们要使用的字段
    fields = (
        'id',
        'name',
        'address'
    )
上一篇 下一篇

猜你喜欢

热点阅读