首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >使用条件循环和删除python中的特定行

使用条件循环和删除python中的特定行
EN

Stack Overflow用户
提问于 2021-07-28 14:42:30
回答 1查看 47关注 0票数 1

我想要删除数据帧中不具有值'X1‘和'1’的所有行。下面是输入和输出的示例,其中包含以下数据帧:

这是我制作的数据框架:

代码语言:javascript
运行
复制
d = {1: [0,0,0, 1,0], 2: [0,0,0, 1,0], 3:[0,0,0,1,0], 4:[0,0,1,1,0], 5:[0,0,1,'X1',0],
     6:[1,0,1,'X1',0],7:[1,0,1,'X1',0],8:[1,0,1,'X1',0],9:[1,0,'X1',0,pd.NaT]}
d = pd.DataFrame(data=d,index=range(1,6))
d

    1   2   3   4   5   6   7   8   9
1   0   0   0   0   0   1   1   1   1
2   0   0   0   0   0   0   0   0   0
3   0   0   0   1   1   1   1   1   X1
4   1   1   1   1   X1  X1  X1  X1  0
5   0   0   0   0   0   0   0   0   NaT

这是我写的代码:

代码语言:javascript
运行
复制
for column in d.columns:
    index_names = d[(d[column] == 1) | (d[column]== 'X1')]
      
index_names

    1   2   3   4   5   6   7   8   9
1   0   0   0   0   0   1   1   1   1
3   0   0   0   1   1   1   1   1   X1

它的效果不是很好!它只考虑最后一列,而不删除第四行。有人知道我哪里错了吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-07-28 14:46:45

您可以尝试通过布尔掩码:

代码语言:javascript
运行
复制
#your condition:
m=(d.eq(1).any(1)) | (d.eq('X1').any(1))

#Finally:
d=d[m]
#OR
d=d.loc[m]

d的输出

代码语言:javascript
运行
复制
    1   2   3   4   5   6   7   8   9
1   0   0   0   0   0   1   1   1   1
3   0   0   0   1   1   1   1   1   X1
4   1   1   1   1   X1  X1  X1  X1  0
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68555589

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档