Chr*_*ris 4 python json mongodb pymongo flask
我正在尝试使用Mongodb集合中的Flask做出回应:
@app.route('/stories', methods = ['GET'])
def get_stories():
stories = db.stories.find()
json_docs = [json.dumps(doc, default=json_util.default) for doc in stories]
resp = jsonify(data=json_docs)
resp.status_code = 200
return make_response(resp)
Run Code Online (Sandbox Code Playgroud)
这将获取所有项目并将其编码为JSON响应,但它看起来像这样:
{
"data": [
"{\"content\": \"some story here\", \"_id\": {\"$oid\": \"5293c34431e20307544db9cb\"}}",
"{\"content\": \"some story here\", \"_id\": {\"$oid\": \"5293c34d31e20307584c3e6e\"}}",
"{\"content\": \"some story here\", \"_id\": {\"$oid\": \"5293c57d31e20307a7b40abe\"}}"
]
}
Run Code Online (Sandbox Code Playgroud)
有没有办法使用单引号对此进行编码,因此它不会添加转义字符串?或者有什么我忽略的东西
你编码两次:
json_docs = [json.dumps(doc, default=json_util.default) for doc in stories]
resp = jsonify(data=json_docs)
Run Code Online (Sandbox Code Playgroud)
现在每个条目json_docs都是一个表示JSON对象的字符串.
删除json.dumps()电话:
resp = jsonify(data=stories)
Run Code Online (Sandbox Code Playgroud)
或者使用flask.json.dump()具有Response():
resp = Response(json.dumps({'data': stories}, default=json_util.default),
mimetype='application/json')
Run Code Online (Sandbox Code Playgroud)
这使您可以json_util.default在游标对象上使用处理程序.
| 归档时间: |
|
| 查看次数: |
5767 次 |
| 最近记录: |