Python - 在 Pandas DataFrame 中用最新的前一个正值替换负值
我们想用最新的前一个正值替换负值。这样,如果前面没有正值,则该值应更新为0。
输入
例如,输入是-
DataFrame: One two 0 -2 -3 1 4 -7 2 6 5 3 0 -9输出结果
输出应该是-
One two 0 0 0 1 7 0 2 4 2 3 0 2
数据框屏蔽用于替换负值。为了填充缺失值,我们使用了正向填充。首先,让我们创建熊猫数据框-
#创建熊猫数据框
df = pd.DataFrame({'One': [-3, 7, 4, 0], 'two': [-6, -1, 2, -8]})让我们进行掩蔽-
df = df.mask(df.lt(0)).ffill().fillna(0).astype('int32')示例
以下是代码-
import pandas as pd
#创建熊猫数据框
df = pd.DataFrame({'One': [-3, 7, 4, 0],'two': [-6, -1, 2, -8]})
#displayingtheDataFrame
print"DataFrame: \n",df
#masking
df = df.mask(df.lt(0)).ffill().fillna(0).astype('int32')
#displayingtheupdatedDataFrame
print"\nUpdated DataFrame: \n",df输出结果这将产生以下输出-
DataFrame: One two 0 -3 -6 1 7 -1 2 4 2 3 0 -8 Updated DataFrame: One two 0 0 0 1 7 0 2 4 2 3 0 2
热门推荐
10 诗词送行祝福语大全简短
11 新房开工吉日祝福语简短
12 50多岁生日简短祝福语
13 安徽疫情祝福语简短英语
14 农民朋友发财祝福语简短
15 对生活祝福语简短精辟
16 搬家词简短祝福语朋友
17 女神结婚快乐祝福语简短
18 文学短句祝福语大全简短