Django objects的查询结果转化为json的三种方式的方法
第一种方式:
利用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,
"辽宁省"
],
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
python openpyxl提取Excel图片实现原理技巧
在这篇文章中,将介绍如何使用openpyxl来提取Excel中的图片,以及它的原理和技巧,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2024-01-01
PyTorch、torchvision和Python版本的对应关系
使用PyTorch时,选择合适的Python版本是至关重要的,错误的版本组合可能导致各种兼容性问题,本文就来介绍一下PyTorch、torchvision与Python版本匹配,感兴趣的可以了解一下2024-03-03


最新评论