繁体   English   中英

将查询结果转换为JSON

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM