1. ホーム
  2. python

[解決済み] Google App EngineのモデルのJSONシリアライゼーション

2023-04-27 08:47:06

質問

私はかなり長い間検索していますが、成功しません。私のプロジェクトはDjangoを使用していませんが、App Engineモデル(google.appengine.ext.db.Model)をJSONにシリアル化する簡単な方法はありますか、または私は独自のシリアライザを書く必要がありますか?

モデルです。

class Photo(db.Model):
    filename = db.StringProperty()
    title = db.StringProperty()
    description = db.StringProperty(multiline=True)
    date_taken = db.DateTimeProperty()
    date_uploaded = db.DateTimeProperty(auto_now_add=True)
    album = db.ReferenceProperty(Album, collection_name='photo')

どのように解決するのですか?

単純な再帰的関数を使って、エンティティ(および参照元)をネストした辞書に変換し、それを simplejson :

import datetime
import time

SIMPLE_TYPES = (int, long, float, bool, dict, basestring, list)

def to_dict(model):
    output = {}

    for key, prop in model.properties().iteritems():
        value = getattr(model, key)

        if value is None or isinstance(value, SIMPLE_TYPES):
            output[key] = value
        elif isinstance(value, datetime.date):
            # Convert date/datetime to MILLISECONDS-since-epoch (JS "new Date()").
            ms = time.mktime(value.utctimetuple()) * 1000
            ms += getattr(value, 'microseconds', 0) / 1000
            output[key] = int(ms)
        elif isinstance(value, db.GeoPt):
            output[key] = {'lat': value.lat, 'lon': value.lon}
        elif isinstance(value, db.Model):
            output[key] = to_dict(value)
        else:
            raise ValueError('cannot encode ' + repr(prop))

    return output