欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django ValuesQuerySet轉(zhuǎn)json方式

 更新時(shí)間:2020年03月16日 12:23:29   作者:翔云123456  
這篇文章主要介紹了Django ValuesQuerySet轉(zhuǎn)json方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

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

result_set = Apple.objects.all().values()

print type(result_set)
data_list = result_set[:] # queryset轉(zhuǎn)為list
print type(data_list)

output:

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

經(jīng)過(guò)轉(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對(duì)象轉(zhuǎn)json【包括嵌套對(duì)象轉(zhuǎn)json,django的model轉(zhuǎn)json】

背景:

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

問(wèn)題:

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

方案(python3.6):

1對(duì)象轉(zhuǎn)json:

model類

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

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

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

結(jié)果:

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

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

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

剛才的People類可看做是嵌套類,即有一個(gè)屬性是另一個(gè)類的實(shí)例,此時(shí),若用上面的方法來(lái)json化Person對(duì)象,會(huì)有問(wèn)題,如下【錯(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只能針對(duì)JSON serializable對(duì)象直接進(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)

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

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

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

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

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

方案:

我們還是使用_ dict _這個(gè)利器,首先,我們根據(jù)pid獲得一個(gè)Person對(duì)象,然后利用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, '沒(méi)有查詢到對(duì)應(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無(wú)用,且影響了結(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, '沒(méi)有查詢到對(duì)應(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ù)庫(kù)查詢后得到QuerySet,其不能直接json化(通過(guò)serializer得到的不好看,也不好處理,大量的屬性處理還比較費(fèi)勁),需要將其遍歷得到每個(gè)對(duì)象,然后將其屬性字典加入到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拼接的過(guò)程,不能直接添加對(duì)象
result ['data'] = L

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

return JsonResponse(result, safe=False)

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

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

以上這篇Django ValuesQuerySet轉(zhuǎn)json方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 10個(gè)簡(jiǎn)單但很有用的Python裝飾器分享

    10個(gè)簡(jiǎn)單但很有用的Python裝飾器分享

    裝飾器(Decorators)是Python中一種強(qiáng)大而靈活的功能,用于修改或增強(qiáng)函數(shù)或類的行為,本文為大家整理了10個(gè)簡(jiǎn)單但很有用的Python裝飾器,希望對(duì)大家有所幫助
    2023-08-08
  • Python?使用和高性能技巧操作大全

    Python?使用和高性能技巧操作大全

    這篇文章主要介紹了Python?使用和高性能技巧總結(jié),對(duì)一些python易混淆的操作進(jìn)行對(duì)比,不少 Python 的用戶是從以前 C/C++ 遷移過(guò)來(lái)的,這兩種語(yǔ)言在語(yǔ)法、代碼風(fēng)格等方面有些不同,本節(jié)簡(jiǎn)要進(jìn)行介紹,需要的朋友可以參考下
    2022-01-01
  • 在Python中關(guān)于中文編碼問(wèn)題的處理建議

    在Python中關(guān)于中文編碼問(wèn)題的處理建議

    這篇文章主要介紹了幾種在Python中關(guān)于中文編碼問(wèn)題的處理方法,包括在使用Unicode編碼時(shí)碰到的異常等,需要的朋友可以參考下
    2015-04-04
  • 淺談Python之Django(三)

    淺談Python之Django(三)

    這篇文章主要介紹了Python3中的Django,小編覺(jué)得這篇文章寫的還不錯(cuò),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧,希望能夠給你帶來(lái)幫助
    2021-10-10
  • Python爬蟲(chóng)實(shí)現(xiàn)使用beautifulSoup4爬取名言網(wǎng)功能案例

    Python爬蟲(chóng)實(shí)現(xiàn)使用beautifulSoup4爬取名言網(wǎng)功能案例

    這篇文章主要介紹了Python爬蟲(chóng)實(shí)現(xiàn)使用beautifulSoup4爬取名言網(wǎng)功能,結(jié)合實(shí)例形式分析了Python基于beautifulSoup4模塊爬取名言網(wǎng)并存入MySQL數(shù)據(jù)庫(kù)相關(guān)操作技巧,需要的朋友可以參考下
    2019-09-09
  • python中enumerate函數(shù)用法實(shí)例分析

    python中enumerate函數(shù)用法實(shí)例分析

    這篇文章主要介紹了python中enumerate函數(shù)用法,以實(shí)例形式較為詳細(xì)的分析了enumerate函數(shù)的功能、定義及使用技巧,需要的朋友可以參考下
    2015-05-05
  • Python datetime模塊使用方法小結(jié)

    Python datetime模塊使用方法小結(jié)

    這篇文章主要介紹了Python datetime模塊使用方法小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • 聯(lián)邦學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)FedAvg算法實(shí)現(xiàn)

    聯(lián)邦學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)FedAvg算法實(shí)現(xiàn)

    這篇文章主要為大家介紹了聯(lián)邦學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)FedAvg算法實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • Python3的socket使用方法詳解

    Python3的socket使用方法詳解

    這篇文章主要介紹了Python3的socket使用方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • python實(shí)現(xiàn)發(fā)送form-data數(shù)據(jù)的方法詳解

    python實(shí)現(xiàn)發(fā)送form-data數(shù)據(jù)的方法詳解

    這篇文章主要介紹了python實(shí)現(xiàn)發(fā)送form-data數(shù)據(jù)的方法,結(jié)合實(shí)例形式分析了Python發(fā)送form-data數(shù)據(jù)的相關(guān)操作步驟、實(shí)現(xiàn)方法與注意事項(xiàng),需要的朋友可以參考下
    2019-09-09

最新評(píng)論