df = pd.DataFrame(np.random.randn(6, 3), columns=['a', 'b', 'c'])
a b c
0 1.877317 0.109646 1.634978
1 -0.048044 -0.837403 -2.198505
2 -0.708137 2.342530 1.053073
3 -0.547951 -1.790304 -2.159123
4 0.214583 -0.856150 -0.477844
5 0.159601 -1.705155 0.963673
我们可以像这样布尔索引
df[df.a > 0]
a b c
0 1.877317 0.109646 1.634978
4 0.214583 -0.856150 -0.477844
5 0.159601 -1.705155 0.963673
我们也可以通过行标签切片,如下所示:
df.ix[[0,2,4]]
a b c
0 1.877317 0.109646 1.634978
2 -0.708137 2.342530 1.053073
4 0.214583 -0.856150 -0.477844
我想同时做这两个操作(所以我避免做一个不必要的副本只是为了做行标签过滤器).我该怎么做呢?
我正在寻找的伪代码:
df[(df.a > 0) & (df.__index__.isin([0,2,4]))]
解决方法:
你几乎拥有它:
In [11]: df[(df.a > 0) & (df.index.isin([0, 2, 4]))]
Out[11]:
a b c
0 1.877317 0.109646 1.634978
4 0.214583 -0.856150 -0.477844
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。