Django objects的查詢結果轉化為json的三種方式
阿新 • • 發佈:2018-11-07
第一種方式:
利用seriallizers
這個方法,官網的解釋說:將複雜的資料結構變成json、xml或者其他的格式
import json from django.core import serializers def area2(request,id): data = {} province = serializers.serialize("json",AreaInfo.objects.filter(parea__isnull=True)) data["data"] = json.loads(province) return JsonResponse(data,safe=False)
輸出的結果如下:
{
data: [
{
model: "myapp1.areainfo",
fields: {
title: "北京市",
parea: null
},
pk: 110000
},
{
model: "myapp1.areainfo",
fields: {
title: "天津市",
parea: null
},
pk: 120000
},
{
model: "myapp1.areainfo",
fields: {
title: "河北省",
parea: null
},
pk: 130000
},
第二種方法,使用list,這也是三種中最簡單的
def area2(request,id): data = {} province = AreaInfo.objects.filter(parea__isnull=True).values() data["data"] = list(province) return JsonResponse(data,safe=False)
結果如下:
{
data: [
{
id: 110000,
title: "北京市",
parea_id: null
},
{
id: 120000,
title: "天津市",
parea_id: null
},
{
id: 130000,
title: "河北省",
parea_id: null
},
{
id: 140000,
title: "山西省",
parea_id: null
},
第三種方法比較原始,利用for迴圈拼裝:
def area2(request,id): data = AreaInfo.objects.filter(parea__isnull=True) list=[] for province in data: list.append([province.id,province.title]) data={'data':list} return JsonResponse(data,safe=False)
執行結果如下:
{
data: [
[
110000,
"北京市"
],
[
120000,
"天津市"
],
[
130000,
"河北省"
],
[
140000,
"山西省"
],
[
150000,
"內蒙古自治區"
],
[
210000,
"遼寧省"
],