python pandas处理无限值inf

38 篇文章 31 订阅
36 篇文章 9 订阅

如果不处理inf,可能导致报错:ValueError: Input contains NaN, infinity or a value too large for dtype('float64').

示例代码

首先构造inf,可以使用:np.inf,也可以使用float("inf"),其中inf指无穷大,-inf值无穷小

import pandas as pd
import numpy as np

dataframe = pd.DataFrame(data=[
    [1, 2, np.inf],
    [4, 5, None],
    [7, 8, np.nan],
    [10, 11, 12],
])

判断是否:全部的值都有限

np.all(np.isfinite(dataframe))

判断行、列是否有限:

np.isfinite(dataframe).all()  # 判断这个维度的所有值 是否有限 True,True,False
np.isfinite(dataframe.T).all()  # 判断每个数据的所有值 是否有限 F F F T,这里nan/None也不是有限的值

替换掉不是有限的值:

dataframe.replace(np.inf, "我曾是inf")  # 局部精准的替换

删除值:

dataframe[np.isfinite(dataframe.T).all()]  # 选择所有有限的数据行(删除inf,nan所在行)
dataframe.loc[:, np.isfinite(dataframe).all()]  # 选择所有有限数据所在列(删除inf,nan所在列)

完整示例

import pandas as pd
import numpy as np

dataframe = pd.DataFrame(data=[
    [1, 2, np.inf],
    [4, 5, None],
    [7, 8, np.nan],
    [10, 11, 12],
])

# 判断全部的值都有限
np.all(np.isfinite(dataframe))

# 判断是否有限
np.isfinite(dataframe).all()  # 判断这个维度的所有值 是否有限 True,True,False
np.isfinite(dataframe.T).all()  # 判断每个数据的所有值 是否有限 F F F T,这里nan/None也不是有限的值

# 替换掉不是有限的值
dataframe.replace(np.inf, "我曾是inf")  # 局部精准的替换

# 删除值
dataframe[np.isfinite(dataframe.T).all()]  # 选择所有有限的数据行(删除inf,nan所在行)
dataframe.loc[:, np.isfinite(dataframe).all()]  # 选择所有有限数据所在列(删除inf,nan所在列)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

呆萌的代Ma

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

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

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

打赏作者

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

抵扣说明:

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

余额充值