我正在与python词典挣扎。我创建了一个类似于:
的字典d = {'0.500': ['18.4 0.5', '17.9 0.4', '16.9 0.4', '18.6 0.4'],
'1.000': ['14.8 0.5', '14.9 0.5', '15.6 0.4', '15.9 0.3'],
'0.000': ['23.2 0.5', '23.2 0.8', '23.2 0.7', '23.2 0.1']}
我想最终得到:
0.500 17.95 0.425
这是关键,平均值为(18.4 + 17.9 + 16.9 + 18.6),平均值为(0.5 + 0.4 + 0.4 + 0.4)
(对于1.000和0.000及其相应的平均值相同)
最初我的字典只有两个值,所以我可以依赖索引:
for key in d:
dvdl1 = d[key][0].split(" ")[0]
dvdl2 = d[key][1].split(" ")[0]
average = ((float(dvdl1)+float(dvdl2))/2)
但现在我希望我的代码可以使用不同的字典长度,例如4(上面的示例)或5或6个值...
干杯!
答案 0 :(得分:5)
for k,v in d.iteritems():
col1, col2 = zip(*[map(float,x.split()) for x in v])
print k, sum(col1)/len(v), sum(col2)/len(v)
...
0.500 17.95 0.425
1.000 15.3 0.425
0.000 23.2 0.525
这是如何运作的:
>>> v = ['18.4 0.5', '17.9 0.4', '16.9 0.4', '18.6 0.4']
首先将每个项目拆分为空格并将float
应用于它们,以便我们获得列表清单:
>>> zipp = [map(float,x.split()) for x in v]
>>> zipp
[[18.4, 0.5], [17.9, 0.4], [16.9, 0.4], [18.6, 0.4]] #list of rows
现在我们可以zip
使用*
作为解压缩,我们将获得列列表。
>>> zip(*zipp)
[(18.4, 17.9, 16.9, 18.6), (0.5, 0.4, 0.4, 0.4)]