首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Flask-Restless从Flask-Sqlalchemy转储十进制值

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

Stack Overflow用户
提问于 2013-02-21 14:53:32
回答 2查看 3.4K关注 0票数 6

我有一个使用Flask-SQLAlchemy的模型:

代码语言:javascript
复制
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时:

代码语言:javascript
复制
  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编码器不能对映射到价格(数值列类型)的Decimal值进行编码。有什么办法可以使用定制的JSON编码器来启用Flask-Restless吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-03-05 20:46:32

下面是我所做的:

代码语言:javascript
复制
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编辑:实际上看起来安装可能就足够了。不需要对代码进行任何更改。

票数 5
EN

Stack Overflow用户

发布于 2013-09-03 08:25:44

正如mickael的回答中所指出的,安装simpejson就足够了。后处理器的正确语法如下:

代码语言:javascript
复制
#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!
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14996264

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档