[英]Convert query result to JSON
我有返回查询结果的python函数:
class Arc_Nodes_Data(Resource):
def get(self):
#Connect to databse
conn = connectDB()
cur = conn.cursor()
#Perform query and return JSON data
try:
cur.execute("SELECT start_location FROM trips UNION SELECT end_location FROM trips")
except:
print("Error executing select")
NodeList = list (i[0] for i in cur.fetchall())
return jsonify ({'id':NodeList})
此函数以以下格式返回结果:
{
"id": [
"a",
"b",
"c"
]
}
我在上面尝试了此功能,以便输出可能像这样:
[{
"id": "a"
}, {
"id": "b"
}, {
"id": "c"
}]
显然我做错了。 我似乎无法很好地操作Python词典,所以也许就是问题所在。 如何获得正确的输出?
您可以使用列表推导来执行所需的操作:
return jsonify ([{'id': x} for x in Nodelist])
这种理解使3个字典各包含一个id元素。
您还可以将最后一行合并为一行:
return jsonify ([{'id': i[0]} for i in cur.fetchall()])
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.