情景
在一次将数据库查询结果手动转化为json数据(obj转json)的过程中,发现前端得到的每条数据都是一样的,,,,简述为,列表存入字典值后值会变化,代码如下:
代码语言:javascript复制res = orm.query_all()
data = []
res_dict = {}
for item in res:
res_dict['acm_id'] = item.acm_id
res_dict['acm_title'] = item.acm_title
data.append(res_dict)
return jsonify(data = data)
结果…可想而知
列表中千篇一律的同一组数据,保留了N遍最后一次dict的值
原因
python 为提高性能,优化内存,像是dict2=dict1并没有真正的将该字典在内存中再次创建,只是指向了相同的object。 在该案例中,对象append到list 中,list存的是dict的地址
解决
拷贝得到一个新字典,每次拷贝都会开辟一块空间存值
代码语言:javascript复制dict2=dict1.copy()
修改后的代码
代码语言:javascript复制res = orm.query_all()
data = []
res_dict = {}
for item in res:
res_dict['acm_id'] = item.acm_id
res_dict['acm_title'] = item.acm_title
data_dict = res_dict.copy()
data.append(data_dict)
return jsonify(data = data)