Django處理枚舉(枚舉模型)及source的使用
1、定義模型類、序列化器類
定義模型類models.py;項目模型類、接口模型類、用例模型類
from django.db import models
class Test_Project(models.Model):
name = models.CharField(help_text='項目名稱', verbose_name='項目名稱',
max_length=60,
unique=True)
desc = models.TextField(help_text='項目描述', blank=True, null=True)
create_time = models.DateTimeField(auto_now_add=True)
update_time = models.DateTimeField(auto_now=True)
class Meta:
db_table = "t_test_project"
verbose_name = "項目表"
verbose_name_plural = verbose_name
ordering = ['id']
def __str__(self):
return self.name
CHOICES = [('1', '項目接口'),('2', '外部接口')]
type = models.CharField(verbose_name='接口類型', help_text='接口類型', max_length=40,default='1', choices=CHOICES)
from django.db import models
class Test_Interface(models.Model):
CHOICES = [
('1', '項目接口'),
('2', '外部接口')
]
name = models.CharField(help_text='接口名稱', verbose_name='接口名稱',
max_length=60,
unique=True)
desc = models.TextField(help_text='接口描述', blank=True, null=True, default='描述')
type = models.CharField(verbose_name='接口類型', help_text='接口類型',
max_length=40,
default='1', choices=CHOICES)
project = models.ForeignKey(Test_Project, on_delete=models.CASCADE)
playcount=models.IntegerField(help_text='訪問量',verbose_name='訪問量',default=0)
commentcount = models.IntegerField(default=0, verbose_name='評論量')
class Meta:
db_table = 't_test_interface'
verbose_name = "接口表"
verbose_name_plural = verbose_name
ordering = ['id']
def __str__(self):
return self.name
from django.db import models
class Test_Testcase(models.Model):
name = models.CharField(help_text='用例名稱', verbose_name='用例名稱',
max_length=60,
unique=True)
desc = models.TextField(help_text='用例名稱', blank=True, null=True)
create_time = models.DateTimeField(auto_now_add=True)
update_time = models.DateTimeField(auto_now=True)
interface = models.ForeignKey(Test_Interface, on_delete=models.CASCADE)
class Meta:
db_table = "t_test_testcase"
verbose_name = "用例表"
verbose_name_plural = verbose_name
ordering = ['id']
def __str__(self):
return self.name
序列化器類設計
from rest_framework import serializers
from ttest.models import Test_Project,Test_Interface
class TProjectSerializer(serializers.ModelSerializer):
class Meta:
model=Test_Project
fields='__all__'
class TInterfaceSerializer(serializers.ModelSerializer):
class Meta:
model=Test_Interface
fields='__all__'
訪問接口:前端展示的數(shù)據(jù)type:“1”
使用默認的序列化器時,視圖函數(shù)訪問 具有choices參數(shù) 的字段或 一對一 或 一對多 或 多對多 字段時,返回的數(shù)據(jù)只有 id 值,就像下面這種方式,性別是0或1

2、對上面這些場景使用source參數(shù)
get_xxx_display 用于顯示 choices 參數(shù)對應的文本信息。
序列化器文件:serializers.py
class TProjectSerializer(serializers.ModelSerializer):
class Meta:
model=Test_Project
fields='__all__'
class TInterfaceSerializer(serializers.ModelSerializer):
type = serializers.ChoiceField(choices=Test_Interface.CHOICES,
source="get_type_display",
read_only=True) # 設置source="get_屬性_display"即可
class Meta:
model=Test_Interface
fields='__all__'

3、支持連表查詢
project_create_time=serializers.CharField(source='project.create_time')
顯示 一對一 或 一對多 或 多對多 字段對應的文本信息。支持連表查詢
from rest_framework import serializers
from ttest.models import Test_Project,Test_Interface
class TProjectSerializer(serializers.ModelSerializer):
class Meta:
model=Test_Project
fields='__all__'
class TInterfaceSerializer(serializers.ModelSerializer):
type = serializers.ChoiceField(choices=Test_Interface.CHOICES,
source="get_type_display",
read_only=True) # 設置source="get_屬性_display"即可
project_create_time=serializers.CharField(source='project.create_time')
class Meta:
model=Test_Interface
fields='__all__'

4、自定義序列化輸出方法
自定義序列化輸出方法,會尋找并執(zhí)行’get_xxx’的方法。
from rest_framework import serializers
from ttest.models import Test_Project,Test_Interface
class TProjectSerializer(serializers.ModelSerializer):
class Meta:
model=Test_Project
fields='__all__'
class TInterfaceSerializer(serializers.ModelSerializer):
type = serializers.ChoiceField(choices=Test_Interface.CHOICES,
source="get_type_display",
read_only=True) # 設置source="get_屬性_display"即可
project_create_time=serializers.CharField(source='project.create_time')
name_zidingyi=serializers.SerializerMethodField()
def get_name_zidingyi(self,obj):
return obj.project.name
class Meta:
model=Test_Interface
fields='__all__'

5、案例5
序列化輸出時改變前端輸出的字段名稱


到此這篇關于Django處理枚舉(枚舉模型)及source的使用的文章就介紹到這了,更多相關Django 枚舉及source內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Python Pandas describe()函數(shù)的使用詳解
pandas庫中的describe()函數(shù)為我們提供了這樣的功能,它可以快速生成數(shù)據(jù)集的描述性統(tǒng)計信息,這篇文章主要介紹了Python Pandas describe()函數(shù)的使用介紹,需要的朋友可以參考下2024-05-05
python實現(xiàn)簡易內(nèi)存監(jiān)控
這篇文章主要介紹了python實現(xiàn)簡易內(nèi)存監(jiān)控,每隔3秒獲取系統(tǒng)內(nèi)存,當內(nèi)存超過設定的警報值時,獲取所有進程占用內(nèi)存并發(fā)出警報聲,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-06-06
解決pyPdf和pyPdf2在合并pdf時出現(xiàn)異常的問題
這篇文章主要介紹了解決pyPdf和pyPdf2在合并pdf時出現(xiàn)異常的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04

