json - 类型错误 : <object> is not JSON serializable

标签 json django object python-2.x

我试图在 Django 中使用 json.dumps() 将对象编码为 json,但是当我传入 python 对象时,它会引发此错误。

TypeError: <OrgInvite: OrgInvite object> is not JSON serializable

我假设即使 JSON 只能对某些数据类型进行编码,但其中一种数据类型是对象。我在 Stack Overflow 上阅读了另一个问题,解决这个问题的一个好方法是使用 .__dict__ 从对象中创建一个字典我试过了,它说我的新字典中的一个键, _state 不可序列化。我不确定这个 _state 键是从哪里来的,我想知道是否有一种方法可以将我的对象转换成没有那个额外字段的字典,这样我就可以将它编码成 JSON?

型号:

class OrgInvite(models.Model):
    token = models.CharField(max_length=16, unique=True, null=False)
    account_id = models.ForeignKey(Account, on_delete=models.CASCADE, null=False)
    org_id = models.ForeignKey(Org, on_delete=models.CASCADE, null=False)
    used = models.BooleanField(default=False)
    is_admin = models.BooleanField(default=False)
    name = models.CharField(max_length=70)
    email = models.CharField(max_length=255)

查看:

def get_invite(token):
    if not token:
        raise Exception("Invitation token is not specified")

    invitation = OrgInvite.objects.get(token=token)
    if not invitation:
        raise Exception("Invitation token is invalid.")

    return invitation

def invite_accept_redirect(token):
    # """ -Redirects to the accept invite frontend view with pre-fetched data. """

    try:
        invite = get_invite(token)
        if not invite:
            raise Exception("Invitation token is invalid")
        if invite.used:
            invite = {'used': True}
    except:
        invite = {'invalid': True}
        raise Exception("Resource not found.")

    base = "home/accept"

    url = '{}/{}?data={}'.format(base, token, urllib.quote_plus(json.dumps(invite.__dict__)))

    return redirect(url)

控制台:

>>> oi = OrgInvite.objects.get(token=100) 
>>> oi
<OrgInvite: OrgInvite object>
>>> oix = oi.__dict__
>>> oix
{'used': False, 'name': u'', '_state': <django.db.models.base.ModelState object at 0x10377a610>, 'email': u'', 'token': u'100', 'org_id_id': 101, 'account_id_id': 301, 'is_admin': False, 'id': 1}
>>> json.dumps(oix)
Traceback (most recent call last):
  File "<console>", line 1, in <module>
  File "/usr/local/Cellar/python/2.7.11/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/__init__.py", line 244, in dumps
    return _default_encoder.encode(obj)
  File "/usr/local/Cellar/python/2.7.11/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/encoder.py", line 207, in encode
    chunks = self.iterencode(o, _one_shot=True)
  File "/usr/local/Cellar/python/2.7.11/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/encoder.py", line 270, in iterencode
    return _iterencode(o, 0)
  File "/usr/local/Cellar/python/2.7.11/Frameworks/Python.framework/Versions/2.7/lib/python2.7/json/encoder.py", line 184, in default
    raise TypeError(repr(o) + " is not JSON serializable")
TypeError: <django.db.models.base.ModelState object at 0x10377a610> is not JSON serializable

最佳答案

__dict__ 给出了实例的所有属性,但您不想要所有这些额外的包袱——出于序列化的目的,您只对字段感兴趣。

您的模型不包含任何特殊内容,因此内置辅助函数 model_to_dict 应该足以满足您的需求:

import json
from django.forms.models import model_to_dict

oi = OrgInvite.objects.get(token=100) 
oi_dict = model_to_dict(oi)
oi_serialized = json.dumps(oi_dict)

您的示例很简单,仅包含 CharFieldBooleanFieldForeignKey,所有这些我们都可以转储到 json 琐碎。

对于更复杂的模型,您可以考虑编写自己的 serializer .在这种情况下,我建议使用流行的 django-rest-framework它为你做了所有的工作。

from rest_framework import serializers

class OrgInviteSerializer(serializers.ModelSerializer):
    class Meta:
        model = OrgInvite
        fields = '__all__'

关于json - 类型错误 : <object> is not JSON serializable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36555602/

相关文章:

javascript - Angularjs $http.get 将 JSON 数据作为带有转义引号而不是 json 的字符串返回

python - 编辑帖子,它几乎可以工作,但是当我单击最终编辑按钮时,它会将我带到 404 页面,为什么? (删除效果很好)

python - Django migrate : django. db.utils.OperationalError : (1364, "Field ' 名称'没有默认值")

javascript - 按属性分组对象

java - Spring Boot 预处理 JSON 数据

regex - 使用 sed 编辑 JSON 文件

javascript - Object.create(prototype) 和 Object(prototype) 的区别

python - 如何在Python中的嵌套对象中设置属性?

ios - 为什么从 NSMutableArray 设置 labels.text 不起作用?

Python、Django - ValueError : "<...>" needs to have a value for field "..." before this many-to-many relationship can be used