Pandas空数据的处理

8 篇文章 0 订阅

原文地址

分类目录——Pandas

  • 导入支持包

    import pandas as pd
    import numpy as np
    
  • 生成测试数据

    dates = pd.date_range('20200220', periods=6)
    df = pd.DataFrame(np.arange(24).reshape((6,4)),index=dates, columns=['A','B','C','D'])
    df.iloc[0,1] = np.nan
    df.iloc[1,2] = np.nan
    '''
                 A     B     C   D
    2020-02-20   0   NaN   2.0   3
    2020-02-21   4   5.0   NaN   7
    2020-02-22   8   9.0  10.0  11
    2020-02-23  12  13.0  14.0  15
    2020-02-24  16  17.0  18.0  19
    2020-02-25  20  21.0  22.0  23
    '''
    
  • 删除缺失数据

    df2 = df.dropna(
        axis=0,     # 0: 对行进行操作; 1: 对列进行操作
        how='any'   # 'any': 只要存在 NaN 就 drop 掉; 'all': 必须全部是 NaN 才 drop
        )
    #              A     B     C   D
    # 2020-02-22   8   9.0  10.0  11
    # 2020-02-23  12  13.0  14.0  15
    # 2020-02-24  16  17.0  18.0  19
    # 2020-02-25  20  21.0  22.0  23
    
  • 在缺失数据处补充值

    df3 = df.fillna(value=0)
    #              A     B     C   D
    # 2020-02-20   0   0.0   2.0   3
    # 2020-02-21   4   5.0   0.0   7
    # 2020-02-22   8   9.0  10.0  11
    # 2020-02-23  12  13.0  14.0  15
    # 2020-02-24  16  17.0  18.0  19
    # 2020-02-25  20  21.0  22.0  23
    

    顺便说一句,在机器学习中通常用来补充的值设定有平均数、中位数、众数等

  • 判断df对象的各位是否为空

    df4 = df.isnull()   # 为空的部分返回True,非空的部位返回False
    #                 A      B      C      D
    # 2020-02-20  False   True  False  False
    # 2020-02-21  False  False   True  False
    # 2020-02-22  False  False  False  False
    # 2020-02-23  False  False  False  False
    # 2020-02-24  False  False  False  False
    # 2020-02-25  False  False  False  False
    
  • 判断df对象中是否存在空值

    # np.any(object), object中有True为True,全False为False
    nullres = np.any(df.isnull())
    # True
    
  • 参考文献

    程序主要来自 Pandas 处理丢失数据

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BBJG_001

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值