Flask-Restless从Flask-Sqlalchemy转储十进制值

des*_*nto 5 python json flask flask-sqlalchemy

我有使用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)
Run Code Online (Sandbox Code Playgroud)

我可以使用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
Run Code Online (Sandbox Code Playgroud)

问题很明显,JSON编码器无法编码映射到价格(数字列类型)的十进制值。是否有任何使用自定义JSON编码器启用Flask-Restless的解决方法?

mic*_*ael 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]
})
Run Code Online (Sandbox Code Playgroud)

因此,我们的想法是使用Flask-Restless的后处理器使用simplejson而不是json编码数据,因为simplejson通过指定use_decimal = True支持Decimal()类型。

编辑:实际上似乎安装simplejson可能就足够了。您的代码无需更改。

  • 只需安装simplejson即可!谢谢。 (3认同)