微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python-拆分DataFrame的奇数行而不使用double iloc

测试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更好的解决方案吗?

解决方法:

这行不行吗?

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐