拆分奇数行的DataFrame,不带双iloc

时间:2016-06-20 07:43:34

标签: python pandas indexing dataframe

测试df

import pandas as pd

df = pd.DataFrame({'A':[1,2,3,7,8,4],
                   'B':[4,5,6,1,4,6],
                   'C':[7,8,9,2,7,3],
                   'D':[4,5,2,1,0,6]})

df.set_index(['A','B'], inplace=True)
print (df)
     C  D
A B      
1 4  7  4
2 5  8  5
3 6  9  2
7 1  2  1
8 4  7  0
4 6  3  6

由奇数行拆分:

print (df.iloc[::2])
     C  D
A B      
1 4  7  4
3 6  9  2
8 4  7  0

我需要再次拆分 - df1中的最后一行和df2的所有其他行:

df1 = df.iloc[-2::2]
df2 = df.iloc[::2].iloc[:-1,:]

print (df1)
     C  D
A B      
8 4  7  0

print (df2)
     C  D
A B      
1 4  7  4
3 6  9  2

没有双iloc的更好的解决方案吗?

1 个答案:

答案 0 :(得分:4)

这不会起作用吗?

df2 = df.iloc[:-2:2]

     C  D
A B      
1 4  7  4
3 6  9  2