a_list = []
b_list = []
c_list = []
d_dict = [{'a': 1, 'b': 2, 'c': 3}, {'a': 11, 'b': 22, 'c': 33}, {'a': 111, 'b': 222, 'c': 333}]
for i in d_dict:
a_list.append(i['a'])
b_list.append(i['b'])
c_list.append(i['c'])
res_dict = {'a': a_list, 'b': b_list, 'c': c_list}
print(res_dict) # {'a': [1, 11, 111], 'b': [2, 22, 222], 'c': [3, 33, 333]}
需要处理的 d_dict 是 django 的一个 queryset,目标是生成一个新的字典,每个 k 对应一个列表,列表里是对应 queryset 某个 k 的所有值。 实际上还有好多字段,所以这段代码在项目里面看起来很臃肿,不知道大家有没有什么优雅的方法。 注意:只用一次 for 循环,
感谢各位提供了很多思路,这是一个django的web项目目前采用了2楼的建议
# 设置字典的内置对象为list
nf_dict = defaultdict(list)
for nf in nf_object_values:
for k, v in dict(nf).items():
if k == 'netflow_timestamp':
nf_dict[k].append(str(v))
else:
nf_dict[k].append(v)
return dict(nf_dict)
1
jakezh 2019-10-29 10:06:17 +08:00
用二维数组吧
|
2
Orenoid 2019-10-29 10:11:19 +08:00
from collections import defaultdict
result = defaultdict(list) for i in d_dict: result['a'].append(i['a']) # b, c 同理 |
3
Orenoid 2019-10-29 10:14:07 +08:00
不过你的键值很多的话不应该用 dict.items() 来做二次循环吗,为什么一定要只用一次循环
|
4
Vegetable 2019-10-29 10:20:27 +08:00
首先你这个 abc_list 完全没必要定义,直接定义一个 res_dict={a:[],b:[].c:[]},就只剩下一行定义+一个循环了,而且可以像 3 楼说的直接
for i in d_dict: for attr in (a,b,c): res_dict[attrname].append(getattr(i,attrname)) 这样两层循环去做 |
5
Vegetable 2019-10-29 10:21:01 +08:00
*for attrname in (a,b,c):
|
6
alienx717 2019-10-29 10:22:35 +08:00
妹得,我怎么感觉只是我以前写的代码哈哈哈
|
7
dapengzhao OP @Orenoid 谢谢解决了,我定一次 for 循环是觉得有人会想用多次字典生成式来做,但是两次 for 循环完美解决
|
8
dapengzhao OP ```
d_dict = [{'a': 1, 'b': 2, 'c': 3}, {'a': 11, 'b': 22, 'c': 33}, {'a': 111, 'b': 222, 'c': 333}] d = defaultdict(list) for i in d_dict: for k, v in i.items(): d[k].append(v) print(dict(d)) ``` |
9
ipwx 2019-10-29 10:41:17 +08:00 1
In [1]: import pandas as pd
In [2]: df = pd.DataFrame(data=[{'a': 1, 'b': 2, 'c': 3}, {'a': 11, 'b': 22, 'c': 33}, {'a': 111, 'b': 222, 'c': 333}], columns=['a', 'b', 'c']) In [3]: res_dict = {k: df[k].tolist() for k in df} In [4]: res_dict Out[4]: {'a': [1, 11, 111], 'b': [2, 22, 222], 'c': [3, 33, 333]} |
10
ipwx 2019-10-29 10:42:27 +08:00
嘛,上面那个用 Pandas 的答案,一次 for 都不用。如果不是 web 应用而是数据处理,那么就是标准答案了。毕竟 pandas 就是用来干这种脏活的。。。
|
11
8Cangtou 2019-10-29 10:54:31 +08:00
{element_key: [n[element_key] for n in d_dict] for element_key in ["a", "b", "c"]}
|
12
8Cangtou 2019-10-29 10:54:54 +08:00
@8Cangtou
d_dict = [{'a': 1, 'b': 2, 'c': 3}, {'a': 11, 'b': 22, 'c': 33}, {'a': 111, 'b': 222, 'c': 333}] print {element_key: [n[element_key] for n in d_dict] for element_key in ["a", "b", "c"]} |
13
xujunfu 2019-10-29 11:07:00 +08:00
In [13]: import pandas as pd
In [14]: d_dict = [{'a': 1, 'b': 2, 'c': 3}, {'a': 11, 'b': 22, 'c': 33}, {'a': 111, 'b': 222, 'c': 333}] In [15]: res_dict = pd.DataFrame(d_dict).to_dict() |
14
Kilerd 2019-10-29 11:07:25 +08:00
@ipwx #9 res_dict = {k: df[k].tolist() for k in df} 这个不是循环吗????
|
15
princelai 2019-10-29 13:50:34 +08:00
```
import pandas as pd pd.DataFrame(d_dict).to_dict('list') ``` 前提是你的 d_dict 里每一个 dict 是一样长 |