av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

Django ValuesQuerySet轉(zhuǎn)json方式

瀏覽:65日期:2024-05-28 17:21:38

在使用ValuesQuerySet存放查詢結(jié)果時(shí),有時(shí)需要轉(zhuǎn)為json,但并不能直接使用json.dumps()直接轉(zhuǎn),而是需要經(jīng)過下面一個(gè)步驟:

result_set = Apple.objects.all().values()print type(result_set)data_list = result_set[:] # queryset轉(zhuǎn)為listprint type(data_list)

output:

<class ’django.db.models.query.ValuesQuerySet’><type ’list’>

經(jīng)過轉(zhuǎn)換之后,data_list可以使用json.dumps()轉(zhuǎn)為json;

為什么要有ValuesQuerySet?

查詢內(nèi)容直接轉(zhuǎn)為字典形式,方便后續(xù)使用;

可以指定查詢哪一列;例如Apple.objects.all().values(‘id’),只會(huì)查詢表中的id這一列;

補(bǔ)充知識(shí):Python對象轉(zhuǎn)json【包括嵌套對象轉(zhuǎn)json,django的model轉(zhuǎn)json】

背景:

給app寫接口時(shí)經(jīng)常會(huì)遇到將一個(gè)model轉(zhuǎn)為json返回。

問題:

網(wǎng)上也有類似方法,只是搜索結(jié)果多少有些問題,總是搜了好一會(huì)兒才找到合適的方法,另外,網(wǎng)上更多集中的只是簡單些的對象,對于復(fù)雜的對象,還是不容易找到好的方式。

方案(python3.6):

1對象轉(zhuǎn)json:

model類

class People(): def __init__(self, name, age, pet): self.name = name self.age = age self.pet = petclass Pet(): def __init__(self, pet_type, pet_name): self.pet_type = pet_type self.pet_name = pet_name

將Pet對象轉(zhuǎn)json:

import jsondef pet2json(): pet = Pet(’Cat’, ’Lili’) js = json.dumps(pet.__dict__) print(js)

結(jié)果:

{“pet_type”: “Cat”, “pet_name”: “Lili”}

小結(jié):充分利用了Python對象的dict方法,Python下一切皆對象,每個(gè)對象都有多個(gè)屬性(attribute),Python對屬性有一套統(tǒng)一的管理方案。dict是用來存儲(chǔ)對象屬性的一個(gè)字典,其鍵為屬性名,值為屬性的值。dict可直接json化。

2嵌套對象轉(zhuǎn)json:

剛才的People類可看做是嵌套類,即有一個(gè)屬性是另一個(gè)類的實(shí)例,此時(shí),若用上面的方法來json化Person對象,會(huì)有問題,如下【錯(cuò)誤】:

def simple_person(): pet = Pet(’Cat’, ’Lili’) p = People(’Xiaoming’, 12,pet) json_data = json.dumps(p.__dict__) print(json_data)

結(jié)果:

報(bào)異常TypeError: Object of type ‘Pet’ is not JSON serializable

原因:json只能針對JSON serializable對象直接進(jìn)行json化,而一般只有內(nèi)置的類型,比如string,int,list和dict等才能直接序列化,代碼中p._ dict _是個(gè)dict類型,但是其pet屬性仍是自定義的類,是不能直接json化的。

解決方式【正確】:

def simple_person(): pet = Pet(’Cat’, ’Lili’) p = People(’Xiaoming’, 12,pet.__dict__) json_data = json.dumps(p.__dict__) print(json_data)

結(jié)果:

{“name”: “Xiaoming”, “age”: 12, “pet”: {“pet_type”: “Cat”, “pet_name”: “Lili”}}

小結(jié):充分利用_ dict _方法。

3django的model轉(zhuǎn)json:

首先有個(gè)model類

class Person(models.Model): name = models.CharField(max_length=50, null=False) age = models.IntegerField(default=0) pid = models.CharField(max_length=20, unique=True) gender = models.IntegerField(default=0)

針對該P(yáng)erson類,有兩種常見情況需要提供其json:

1:根據(jù)pid查詢person記錄;

2:根據(jù)某些條件,查詢一些person記錄。

此時(shí)數(shù)據(jù)庫里已經(jīng)插入了一些數(shù)據(jù)

這里要提一下網(wǎng)上比較常見的一種方式,需要用到django.core.serializers,這個(gè)類的serialize(format, queryset, **options)方法,很明顯,這個(gè)方式只能作用與queryset格式,并且通過例子(不再列出),得到的結(jié)果類似這種 [{“model”: “polls.person”, “pk”: 2, “fields”: {“name”: “Cysion”, “age”: 29, “pid”: “3708261989”, “gender”: 0}}],出現(xiàn)了model,pk,field等屬性,不但用不到(對app來說),而且還增加了其它屬性的使用復(fù)雜度。這個(gè)在官網(wǎng)的說明文檔里也是如此處理,但是作者并不推薦。

方案:

我們還是使用_ dict _這個(gè)利器,首先,我們根據(jù)pid獲得一個(gè)Person對象,然后利用dict方法打印看看結(jié)果(錯(cuò)誤)

req_pid=3708262007//request中得到 try: rt = Person.objects.get(pid=req_pid) print(rt.__dict__) return HttpResponse(json.dumps(rt.__dict__),content_type=’application/json’) # return JsonResponse(rt.__dict__, safe=False)//另一種方式 except: return JsonResponse(datalogic.get_comon_resp(1, ’沒有查詢到對應(yīng)數(shù)據(jù)’))

結(jié)果是:

print結(jié)果{‘_state’: < django.db.models.base.ModelState object at 0x0000000004C80860 >, ‘id’: 17, ‘name’: ‘zhaoliu’, ‘a(chǎn)ge’: 10, ‘pid’: ‘3708262007’, ‘gender’: 1}

嘖嘖,又多了些屬性,特別是這個(gè)_state,是不能序列化的,所以上述并不能直接返回想要的結(jié)果。

解決方式:既然_state無用,且影響了結(jié)果,那我們直接臨時(shí)除去,不就返回了想要的結(jié)果嗎(正確)。

req_pid = request.POST.get(’pid’) try: rt = Person.objects.get(pid=req_pid) rt.__dict__.pop('_state') return JsonResponse(rt.__dict__, safe=False) except: return JsonResponse(datalogic.get_comon_resp(1, ’沒有查詢到對應(yīng)數(shù)據(jù)’))

接口返回結(jié)果是:

{ 'id': 17, 'name': 'zhaoliu', 'age': 10, 'pid': '3708262007', 'gender': 1}

正是客戶端需要的。

最后,是返回列表的,比如需要這種結(jié)果

{ 'code': 0, 'msg': '成功', 'data': [ { 'id': 2, 'name': 'Cysion', 'age': 29, 'pid': '3708261989', 'gender': 0 }, { 'id': 11, 'name': 'Sophia', 'age': 22, 'pid': '3708261998', 'gender': 1 }, { 'id': 15, 'name': 'lisi', 'age': 13, 'pid': '3708262005', 'gender': 0 } ]}

實(shí)現(xiàn)思路同上面類似,首先數(shù)據(jù)庫查詢后得到QuerySet,其不能直接json化(通過serializer得到的不好看,也不好處理,大量的屬性處理還比較費(fèi)勁),需要將其遍歷得到每個(gè)對象,然后將其屬性字典加入到list中,最后將其添加到通用dict中

pers = Person.objects.all()result = {'code':0,'msg':'成功'}L = []for p in pers: p.__dict__.pop('_state')//需要除去,否則不能json化 L.append(p.__dict__)//注意,實(shí)際是個(gè)json拼接的過程,不能直接添加對象result [’data’] = L

這個(gè)時(shí)候result 就是個(gè)可以直接json化的對象了,通過

return JsonResponse(result, safe=False)

可以返回上面需要的結(jié)果。

主要提供了思路,詳細(xì)代碼就不提供了。

以上這篇Django ValuesQuerySet轉(zhuǎn)json方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 国产精品久久久久久一区二区三区 | 综合久久亚洲 | 久一精品| xx视频在线观看 | 国产一区精品 | 一级毛片视频免费观看 | 亚洲 欧美 综合 | 亚洲综合无码一区二区 | 精品一区二区久久久久久久网站 | 国产视频一区二区三区四区五区 | 国产一区二区三区 | 欧美一区二区三区视频 | 亚洲国产成人精品久久 | 国产一区二区三区网站 | 91久久伊人 | 自拍视频国产 | 亚洲最新网址 | 日日夜夜操天天干 | 国产wwwcom | 日韩在线| 久久久久久久久久久蜜桃 | 久婷婷 | 免费成人高清在线视频 | 成人在线免费电影 | 欧美区日韩区 | 在线播放中文字幕 | 我要看一级片 | www国产成人免费观看视频,深夜成人网 | 91av在线看 | 不卡av在线 | 免费观看一级特黄欧美大片 | 亚洲一区欧美 | 99久久精品国产毛片 | 亚洲综合一区二区三区 | 天天操网 | 一区二区三区国产 | 91国在线 | av片在线观看网站 | 91在线视频在线观看 | 精产国产伦理一二三区 | 国产亚洲黄色片 |