django 解決自定義序列化返回處理數(shù)據(jù)為null的問題
在接口返回?cái)?shù)據(jù)時(shí),如果數(shù)據(jù)庫表中查詢出來的某些字段為null時(shí),在前端需要多處理一些數(shù)據(jù)異常的情況。
django可以自定義序列化返回處理,將返回的內(nèi)容限制和預(yù)處理再返回到前端。
1.未處理時(shí)返回
如圖上,有email、mobile這兩個(gè)字段是有可以為空且默認(rèn)值為null的。
2.to_representation處理
在模型序列化類增加, to_representation方法,以自定義數(shù)據(jù)處理限制
from rest_framework import serializersfrom .models import UserInfoclass UserInfoSerializer(serializers.ModelSerializer): class Meta: model = UserInfo # fields = ’__all__’ fields = ( ’id’, ’email’, ’date_create’, ’mobile’, ’email’, ’notice_voice’, ’notice_email’, ’notice_sms’, ’notice_push’) def to_representation(self, instance): data = super().to_representation(instance) if not data[’email’]: data[’email’] = '' if not data[’mobile’]: data[’mobile’] = '' return data
3.處理后前端獲取
補(bǔ)充知識:Django query查詢正常,返回對象為空QuerySet
我出現(xiàn)這個(gè)錯(cuò)誤的前提條件:
數(shù)據(jù)為導(dǎo)入的數(shù)據(jù),并不是正常從前端添加入庫的。
問題現(xiàn)象:
views里獲取數(shù)據(jù)庫查詢對象集合 obj= models.表名.objects.filter(**kwargs)
控制臺debug發(fā)現(xiàn) obj為QuerySet<[]>
拿著query到數(shù)據(jù)庫里執(zhí)行sql ,還能查出數(shù)據(jù),就是沒返回
解決問題:
查看數(shù)據(jù)庫字段是否符合models中定義的格式,如,是否有默認(rèn)值,
將數(shù)據(jù)庫為空字段修改成和models一樣的,有個(gè)快速比對的方法,從前端向數(shù)據(jù)庫添加一條數(shù)據(jù),拿這個(gè)正式數(shù)據(jù)和導(dǎo)入數(shù)據(jù)做比對,哪里不一樣,修改哪里即可。
以上這篇django 解決自定義序列化返回處理數(shù)據(jù)為null的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. python如何實(shí)現(xiàn)word批量轉(zhuǎn)HTML2. python excel和yaml文件的讀取封裝3. Java8內(nèi)存模型PermGen Metaspace實(shí)例解析4. python3實(shí)現(xiàn)往mysql中插入datetime類型的數(shù)據(jù)5. python爬蟲實(shí)戰(zhàn)之制作屬于自己的一個(gè)IP代理模塊6. moment轉(zhuǎn)化時(shí)間戳出現(xiàn)Invalid Date的問題及解決7. python中PyQuery庫用法分享8. Django 權(quán)限管理(permissions)與用戶組(group)詳解9. App啟動優(yōu)化-Android性能優(yōu)化10. python實(shí)現(xiàn)讀取類別頻數(shù)數(shù)據(jù)畫水平條形圖案例
