【发布时间】:2017-10-09 19:06:21
【问题描述】:
我正在尝试从查询中返回 JSON 响应。我见过诸如 (https://rayed.com/wordpress/?p=1508) 之类的示例,但它们不包含传递 HTML 模板。我收到一条错误消息“字典更新序列元素 #0 的长度为 510;需要 2”
型号
class APCPlats(models.Model):
PlatsProjected = models.IntegerField(db_column='Projected', blank=True, null=True)
PlatsCompleted = models.IntegerField(db_column='Complete', blank=True, null=True)
Month = models.CharField(db_column='Month', max_length=200 , blank=True, null=True)
def __str__(self):
return self.Month
class Meta:
managed = True
db_table = 'APCPlats'
查看
def APCChart(request):
apcdata = APCPlats.objects.all()
apcchart = serializers.serialize('json', apcdata)
return render(request, 'apc.html', JsonResponse(apcchart, safe=False))
解决方案:
创建以下类:
class DecimalJSONEncoder(json.JSONEncoder):
def default(self, o):
if type(o) == Decimal:
# Here You can decide if You want decimal to be converted
# to string or float.
return float(o)
if isinstance(o, datetime.datetime):
#return o.replace(tzinfo=None).isoformat()
return datetime.datetime.strftime(o, "%Y/%m/%d")
return super(DecimalJSONEncoder, self).default(o)
如何在您的查询集上使用该类:
json_data = json.dumps(queryset, cls=DecimalJSONEncoder)
确保您导入以下内容:
from django.core.serializers.json import DjangoJSONEncoder
【问题讨论】:
-
您为什么要尝试使用带有 JSON 的 HTML 模板?您是否尝试将 HTML 作为 JSON 返回? HTML中的JSON?预期的结果是什么?
-
@kichik 我不久前解决了这个问题。我需要将 Django 中的查询转换为 JSON 以传递到谷歌图表 API。现在一切都很好。