python删除全0列_python – 如何删除Pandas中仅包含零的列?

df.loc[:, (df != 0).any(axis=0)]

以下是它如何工作的细分:

In [74]: import pandas as pd

In [75]: df = pd.DataFrame([[1,0,0,0], [0,0,1,0]])

In [76]: df

Out[76]:

0 1 2 3

0 1 0 0 0

1 0 0 1 0

[2 rows x 4 columns]

df!= 0创建一个布尔数据帧,它是真的,其中df是非零的:

In [77]: df != 0

Out[77]:

0 1 2 3

0 True False False False

1 False False True False

[2 rows x 4 columns]

(df!= 0).any(axis = 0)返回一个布尔系列,表示哪些列具有非零项. (any操作将沿0轴的值 – 即沿着行 – 聚合成一个布尔值.因此结果是每列的一个布尔值.)

In [78]: (df != 0).any(axis=0)

Out[78]:

0 True

1 False

2 True

3 False

dtype: bool

并且df.loc可用于选择这些列:

In [79]: df.loc[:, (df != 0).any(axis=0)]

Out[79]:

0 2

0 1 0

1 0 1

[2 rows x 2 columns]

要“删除”零列,请重新分配df:

df = df.loc[:, (df != 0).any(axis=0)]

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值