/ / JSONはDjangoモデルの__dict__をシリアル化する方法は? - python、json、django、dictionary、django-1.7

JSONはDjangoモデルの__dict__をシリアル化する方法は? - python、json、django、dictionary、django-1.7

私はDjangoで単一のモデルの値をシリアル化したいと思います。私は使用したいので get(), values() 利用できません。しかし、私は読んだ Googleグループで 値にアクセスするには __dict__.

from django.http import HttpResponse, Http404
import json
from customer.models import Customer

def single(request, id):
try:
model = Customer.objects.get(id=id, user=1)
except Customer.DoesNotExist:
raise Http404
values = model.__dict__
print(values)
string = json.dumps(values)
return HttpResponse(string, content_type="application/json")

printステートメントはこれを出力します。

{"_state": <django.db.models.base.ModelState object at 0x0000000005556EF0>, "web
site": "http://example.com/", "name": "Company Name", "id": 1, "logo": "", "use
r_id": 1, "address3": "City", "notes": "", "address2": "Street 123", "address1": "Company Name", "ustid": "AB123456789", "fullname": "Full Name Of Company Inc.", "mail": "contact@example.com"}

のために _state 次の行はこのエラーで失敗します。

<django.db.models.base.ModelState object at 0x0000000005556EF0> is not JSON serializable

どのようにして返された辞書を直列化できますか? __dict__ なし _state 含まれていますか?

回答:

回答№1は14

model_to_dict() あなたが必要とするものです:

from django.forms.models import model_to_dict

data = model_to_dict(model)
data["logo"] = data["logo"].url
return HttpResponse(json.dumps(data), content_type="application/json")

指定することにより fields そして exclude キーワード引数を使用すると、シリアル化するフィールドを制御できます。

また、 try/except ショートカットを使用してブロックする get_object_or_404()

model = get_object_or_404(Customer, id=id, user=1)

回答№2の場合は1

ソースコードを確認するdjango / core / serializers /__その中に__.py コメント:

Interfaces for serializing Django objects.

Usage::

from django.core import serializers
json = serializers.serialize("json", some_queryset)
objects = list(serializers.deserialize("json", json))

To add your own serializers, use the SERIALIZATION_MODULES setting::

SERIALIZATION_MODULES = {
"csv" : "path.to.csv.serializer",
"txt" : "path.to.txt.serializer",
}

1つのオブジェクトに対して

json = serializers.serialize("json", some_queryset[0:1])

回答№3の場合は0

実際に使用することが可能であることがわかった values() 一緒に get()。フィルタリングされたセットから値を取得するだけで済みます。

def single(request, id):
user = 1
try:
models = Customer.objects.filter(id=id, user=user)
values = models.values().get()
except Customer.DoesNotExist:
raise Http404
string = json.dumps(values)
return HttpResponse(string, content_type="application/json")