我正在尝试使用来自 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)
这会获取所有项目并将其编码为 JSON 响应,但它看起来像这样:
{
"data": [
"{\"content\": \"some story here\", \"_id\": {\"$oid\": \"5293c34431e20307544db9cb\"}}",
"{\"content\": \"some story here\", \"_id\": {\"$oid\": \"5293c34d31e20307584c3e6e\"}}",
"{\"content\": \"some story here\", \"_id\": {\"$oid\": \"5293c57d31e20307a7b40abe\"}}"
]
}
有没有一种方法可以使用单引号对此进行编码,这样它就不会添加到转义字符串中?还是我忽略了什么
最佳答案
您正在编码两次:
json_docs = [json.dumps(doc, default=json_util.default) for doc in stories]
resp = jsonify(data=json_docs)
现在 json_docs
中的每个条目都是一个表示 JSON 对象的字符串。
删除 json.dumps()
调用:
resp = jsonify(data=stories)
或将 flask.json.dump()
与 Response()
一起使用:
resp = Response(json.dumps({'data': stories}, default=json_util.default),
mimetype='application/json')
这让您仍然可以在光标对象上使用 json_util.default
处理程序。
关于python - PyMongo 和 Flask 的 Jsonify 包含转义斜杠,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20204456/