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 编码器无法编码映射到价格(数字列类型)的十进制值。是否有任何方法可以使用自定义 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 的后处理器用 simplejson 而不是 json 对数据进行编码,因为 simplejson 通过指定 use_decimal=True 来支持 Decimal() 类型。

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

于 2013-03-05T12:46:31.973 回答
4

如 mickael 的回答所示,安装 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 回答