本人今日写后端调数据库连接的时候遇到一个抽象问题
raw_userlist = db.session.execute( text("select * from user") ).fetchall()
return jsonify({"data":[dict(x) for x in raw_userlist]})
我试图通过以上代码将获取自数据库的数据转化为字典传递。结果遇到了以下问题,翻阅全网没有可以解决的。
TypeError: cannot convert dictionary update sequence element #0 to a sequence
观察发现,raw_userlist获取的数据是一个它自定义对象roll的list,而且没有email、name等这样的表名,而且不是python自带的数据类型,非常难以操作。
通过查阅官方文档,我们能发现提取到数据和index的方法
这就好办了,我们可以直接暴力提取列表中的有效部分,然后自己生成dict,封装成自己的小插件,代码如下,可以直接复制粘贴使用~。
def list_row2list_dic(list_row):
dic_temp = {}
list_dic = []
for x in list_row:
listda = []
listidx= []
for dx in x:
listda.append(dx)
xx = x._key_to_index
for idx in xx:
listidx.append(idx)
dic_temp=dict(zip(listidx,listda))
list_dic.append(dic_temp)
return list_dic
完美解决。