6

我认为反向/负 dataframe.drop 功能将是一个非常有用的工具。有人对此有过克服吗?

4

2 回答 2

6

通常,我发现自己在获得选择的逆时使用布尔索引和波浪号运算符,而不是 df.drop(),尽管当布尔索引用于形成要删除的标签数组时,相同的概念适用于 df.drop . 希望有帮助。

In [44]: df
Out[44]: 
          A         B
0  0.642010  0.116227
1  0.848426  0.710739
2  0.563803  0.416422

In [45]: cond = (df.A > .6) & (df.B > .3)

In [46]: df[cond]
Out[46]: 
          A         B
1  0.848426  0.710739

In [47]: df[~cond]
Out[47]: 
          A         B
0  0.642010  0.116227
2  0.563803  0.416422
于 2012-09-30T04:49:45.753 回答
3

如果我理解正确,您可以通过在索引上使用“isin”进行索引来获得这种效果:

>>> df
         A         B         C
0  0.754956 -0.597896  0.245254
1 -0.987808  0.162506 -0.131674
2 -1.064639 -2.193629  1.814078
3 -0.483950 -1.290789  1.776827
4 -0.191055 -0.461204  0.412220
>>> df[df.index.isin([0, 2, 3])]   # Drop rows whose label is not in the set [0, 2, 3]
         A         B         C
0  0.754956 -0.597896  0.245254
2 -1.064639 -2.193629  1.814078
3 -0.483950 -1.290789  1.776827
于 2012-09-28T18:59:47.293 回答