2017-06-15 63 views
2

我创建了一个数据框字典来存储我的数据。我需要为每个数据框做一些东西,我试图使用iteritems()遍历字典。但不知何故,我似乎无法对数据帧做任何事情。代码编译并不会抛出任何错误,它似乎没有做任何事情。在使用iteritems时在字典中操作熊猫数据框()

这里我的代码的简化:

这只是让dataframes

dic={} 
df1=pd.DataFrame(np.random.randn(10,5),columns=['a','b','c','d','e']) 
df2=pd.DataFrame(np.random.randn(10,5),columns=['a','b','c','d','e']) 
df3=pd.DataFrame(np.random.randn(10,5),columns=['a','b','c','d','e']) 
df4=pd.DataFrame(np.random.randn(10,5),columns=['a','b','c','d','e']) 
df5=pd.DataFrame(np.random.randn(10,5),columns=['a','b','c','d','e']) 

dic[1]=df1 
dic[2]=df2 
dic[3]=df3 
dic[4]=df4 
dic[5]=df5 

的样本字典,这是一组基本的东西我想要做的每个数据帧。

for key, item in dic.iteritems(): 
    item=item.reset_index()  
    item['Rank']=(item.index)+1 

因此,迭代之后我期待每一个数据帧有一个与旧索引一个额外的列,另有额外的列与“等级”,例如:

Expected

相反,据帧似乎是操作的影响,看起来和以前一样:

Reality

我也尝试在迭代中使用临时数据框,然后尝试将其写入“item”中,并得到相同的结果。我只是想知道我想要做什么甚至可能,或者我可能需要绕过它,并使用不同的方法来实现我的目标。

回答

0

我认为你需要分配DataFrame背部而已,也若想python 2 and 3代码使用items()

for key, item in dic.items(): 
    item=item.reset_index()  
    item['Rank']=(item.index)+1 
    dic[key] = item 

print (dic[1]) 
    index   a   b   c   d   e Rank 
0  0 -1.085631 0.997345 0.282978 -1.506295 -0.578600  1 
1  1 1.651437 -2.426679 -0.428913 1.265936 -0.866740  2 
2  2 -0.678886 -0.094709 1.491390 -0.638902 -0.443982  3 
3  3 -0.434351 2.205930 2.186786 1.004054 0.386186  4 
4  4 0.737369 1.490732 -0.935834 1.175829 -1.253881  5 
5  5 -0.637752 0.907105 -1.428681 -0.140069 -0.861755  6 
6  6 -0.255619 -2.798589 -1.771533 -0.699877 0.927462  7 
7  7 -0.173636 0.002846 0.688223 -0.879536 0.283627  8 
8  8 -0.805367 -1.727669 -0.390900 0.573806 0.338589  9 
9  9 -0.011830 2.392365 0.412912 0.978736 2.238143 10 
+0

人,这是真棒。它像一个魅力!我知道我只是失去了一些东西。 –

+0

现在,我有你在这里,iteritems()和items()之间有什么区别... iseritems()已弃用? –

+0

对我来说很难,但[这里](https://stackoverflow.com/a/3294899/2901002)它解释得更好。 – jezrael

-1

分配项目的数据帧回DIC [关键]

for key, item in dic.items(): 
    item=item.reset_index()  
    item['Rank']=(item.index)+1 
    dic[key] = item 
+0

刚来晚了一点,但你也明白了!谢谢 ! –