在 Python 中用零替换 NaN 并填充负无穷大值

pythonnumpyserver side programmingprogramming

要用零替换 NaN 并用较大的有限数替换无穷大,请使用 Python 中的 numpy.nan_to_num() 方法。该方法返回 x,其中非有限值被替换。如果 copy 为 False,则这可能是 x 本身。第一个参数是输入数据。第二个参数是 copy,是创建 x 的副本(True)还是就地替换值(False)。仅当转换为数组不需要副本时才会发生就地操作。默认值为 True。

第三个参数是 nan,用于填充 NaN 值的值。如果没有传递任何值,则 NaN 值将替换为 0.0。第四个参数 posinf,用于填充正无穷大值的值。如果没有传递任何值,则正无穷大值将替换为 a。第 5 个参数 neginf 是用于填充负无穷值的值。如果没有传递任何值,则负无穷值将被替换为非常小(或负)的数字。

步骤

首先,导入所需的库 −

import numpy as np

使用 array() 方法创建 numpy 数组 −

arr = np.array([np.inf, -np.inf, np.nan, -128, 128])

显示数组 −

print("我们的数组...\n",arr)

检查维度 −

print("\n数组的维度...\n",arr.ndim)

获取数据类型 −

print("\n我们的数组对象的数据类型...\n",arr.dtype)

获取形状 −

print("\n我们的数组对象的形状...\n",arr.shape)

要将 NaN 替换为零并将无穷大替换为较大的有限数,请使用 numpy.nan_to_num() 方法 −

print("\n结果...\n",np.nan_to_num(arr, neginf = 22222))

示例

import numpy as np

# 使用 array() 方法创建 numpy 数组
arr = np.array([np.inf, -np.inf, np.nan, -128, 128])

# 显示数组
print("我们的数组...\n",arr)

# 检查维度
print("\n数组的维度...\n",arr.ndim)

# 获取数据类型
print("\n我们的数组对象的数据类型...\n",arr.dtype)

# 获取形状
print("\n我们的数组对象的形状...\n",arr.shape)

# 要将 NaN 替换为零并将无穷大替换为较大的有限数,请使用 Python 中的 numpy.nan_to_num() 方法
print("\n结果...\n",np.nan_to_num(arr, neginf = 22222))

输出

我们的数组...
[ inf -inf nan -128. 128.]

我们的数组的维度...
1

我们的数组对象的数据类型...
float64

我们的数组对象的形状...
(5,)

结果...
[ 1.79769313e+308 2.22220000e+004 0.00000000e+000 -1.28000000e+002
1.28000000e+002]

相关文章