6

私はFlask-SQLAlchemyを使用してこのモデルを持っています:

class Menu(Document, db.Model):
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    name = db.Column(db.String(80), unique=True, index=True)
    price = db.Column(db.Numeric)

そして、このモデルに Flask-Restless を使用して API を作成できます。問題は、API URL から HTTP GET を実行するときです。

  File "/usr/lib/python2.6/json/encoder.py", line 344, in default
    raise TypeError(repr(o) + " is not JSON serializable")
TypeError: Decimal('10000.0000000000') is not JSON serializable

問題は、JSON エンコーダーが価格 (数値列タイプ) にマップされる 10 進数値をエンコードできないことは明らかです。カスタム JSON エンコーダーを使用して Flask-Restless を有効にする回避策はありますか?

4

2 に答える 2

5

これが私がしたことです:

import simplejson as json

def postprocessor(data):
    json.dumps(data, use_decimal=True)
    return data

manager.create_api(Menu, methods=['GET', 'POST', 'PATCH'], allow_patch_many=True, postprocessors={
'PATCH_MANY': [postprocessor],
'GET_MANY': [postprocessor],
'POST': [postprocessor]
})

したがって、Flask-Restless のポストプロセッサを使用して、json の代わりに simplejson でデータをエンコードするというアイデアがあります。これは、simplejson が use_decimal=True を指定して Decimal() 型をサポートしているためです。

編集:実際には、simplejson をインストールするだけで十分なようです。コードを変更する必要はありません。

于 2013-03-05T12:46:31.973 に答える
4

mickael's answer に示されているように、simpejson をインストールするだけで十分でした。また、ポストプロセッサの正しい構文は次のとおりです。

#first argument must be named as 'result', not 'data'
def postprocessor(result):
    json.dumps(result, use_decimal=True)
    #return data - postprocessors/preprocessors should not return values!
于 2013-09-03T00:25:43.660 に答える