小编War*_*fet的帖子

pandas 用 nan 值剪切了一系列

我想将 pandas cut 函数应用于包含 NaN 的系列。所需的行为是将非 NaN 元素分桶并为 NaN 元素返回 NaN。

import pandas as pd
numbers_with_nan = pd.Series([3,1,2,pd.NaT,3])
numbers_without_nan = numbers_with_nan.dropna()
Run Code Online (Sandbox Code Playgroud)

切割适用于没有 NaN 的系列:

pd.cut(numbers_without_nan, bins=[1,2,3], include_lowest=True)
0      (2.0, 3.0]
1    (0.999, 2.0]
2    (0.999, 2.0]
4      (2.0, 3.0]
Run Code Online (Sandbox Code Playgroud)

当我剪切包含 NaN 的系列时,元素 3 正确返回为 NaN,但最后一个元素分配了错误的 bin:

pd.cut(numbers_with_nan, bins=[1,2,3], include_lowest=True)
0      (2.0, 3.0]
1    (0.999, 2.0]
2    (0.999, 2.0]
3             NaN
4    (0.999, 2.0]
Run Code Online (Sandbox Code Playgroud)

我怎样才能得到以下输出?

0      (2.0, 3.0]
1    (0.999, 2.0]
2    (0.999, 2.0]
3             NaN
4      (2.0, 3.0]
Run Code Online (Sandbox Code Playgroud)

python nan pandas

4
推荐指数
1
解决办法
4625
查看次数

标签 统计

nan ×1

pandas ×1

python ×1