flask 的 jsonify 自动排序问题
背景
·Python 在写接口的时候有时需要返回 json 格式的数据给客户端 ·最简单的方式就是用 flask 的 jsonify,能直接将字典格式化为 json 的形式进行传输
例如
from flask import jsonify ... ... ... def return_success(data): """返回成功信息""" return jsonify(data)
通过以上 jsonify 的方式大部分需求是能够搞定的
问题引发
但是有时候我们要传递的 json 格式可能是这样的
{ "1":[], "2":[], "3":[], ... ... "9":[], “10”:[] }
就是以数字或者有数字标识(例如:rank1,rank2…)的作为 key
乍一看没有什么问题,但是,一旦这个 key 超过 9,也就是10 + 的时候,由于 jsonify 有自动排序的功能,那么以上我们想要的格式就会变成这样:
{ "1":[], “10”:[], "2":[], "3":[], ... ... "9":[] }
显然这不是我们想要的结果,我们就是想要按数字的从小到大的顺序来展示
那 jsonify 就不满足我们的需求了
问题解决
可以借助 flask 的另外一个组件:Response
,然后通过 json.dumps()
方法来避免自动排序
但是这个组件需要指定数据格式,例如:Response(json.dumps(data), mimetype=application/json)
具体实现
import json from flask import Response ··· ··· ··· def return_success(data): """返回成功信息""" return Response(json.dumps(data), mimetype=application/json)
上一篇:
通过多线程提高代码的执行效率例子
下一篇:
【文档】web系统非功能性需求