python - PyMongo 和 Flask 的 Jsonify 包含转义斜杠

标签 python json mongodb flask pymongo

我正在尝试使用来自 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/

相关文章:

python - 数据框 : select different index for each columns

python - 如何调试django crontab?

python - if语句检查字符串是否有大写字母、小写字母和数字

json - JSON 和 YAML 是否有相当于 DTD 或 XML 架构的工具?

android - 改造给出错误 Expected BEGIN_OBJECT but was BEGIN_ARRAY

java - 是否可以使用 Spring 在两个不同的数据库(MongoDB 和 MySQL)中进行包含插入的事务?

javascript - Mongo - 多个引用对象数组中的值的总和

python - 有没有办法在 python 中动态创建/修改函数

java - 如何按插入时的顺序遍历所有 json 值?

javascript - 模型未使用 mongoose 保存到 MongoDB