机器学习异常值处理 逻辑汇总一

一 清除数据中恒定不变值

如果某个数据长时间不变,默认异常,清除掉该部分数据:

python 复制代码
# 使用 `shift` 和 `cumsum` 来创建一个分组键,每次值改变都会增加组号
g = (df['沉淀池3号进水流量'] != df['沉淀池3号进水流量'].shift()).cumsum()

# 使用 `transform` 来计算每个组的大小
counts = df.groupby(g)['沉淀池3号进水流量'].transform('count')
print('counts:', counts)
# 应用一个布尔掩码,将连续出现至少5次的值替换为 NaN
df.loc[counts >= 5, '沉淀池3号进水流量'] = np.nan

# 现在df中的'column_name'列已经将所有连续5个相同的值替换为了 NaN
df.info()

二 清除超出范围的值

指定数据范围外的值清洗:

python 复制代码
df['原水浊度'] = df['原水浊度'].apply(lambda x: x if 0.01 <= x <= 3 else None)

三 使用其中一列数据替换另一列数据

python 复制代码
all_data.loc[all_data['温度'].isnull(), '温度'] = all_data.loc[all_data['温度'].isnull(), '温度2']

四 指定条件替换某一部分数据 np.where

python 复制代码
df['沉后水浊度3'] = np.where(df.index > mid_time, 0.1, df['沉后水浊度3'])
相关推荐
Deepoch1 分钟前
智能清洁新纪元:移动式收垃圾机器人如何重塑城市环卫服务体系
人工智能·机器人·具身模型·deepoc·环卫机器人
ZEGO即构开发者2 分钟前
AI降噪,AI打分,AI唱歌?在线KTV+AI,让每一次欢唱“声”机勃勃
人工智能·在线ktv
南山安6 分钟前
Qoder:CLI与IDE,未来编程的双引擎模式
人工智能
其美杰布-富贵-李6 分钟前
TensorBoard 与 WandB 在 PyTorch Lightning 中的完整指南
人工智能·pytorch·python·监控·调优
冬奇Lab7 分钟前
RAG完全指南:从"死记硬背"到"开卷考试"的AI进化之路
人工智能·llm
水境传感 张园园9 分钟前
土壤蒸渗仪:土壤水分动态的“记录仪”
人工智能
啵啵鱼爱吃小猫咪10 分钟前
一个机械臂抓取项目的复现
人工智能·机器人
LaughingZhu10 分钟前
Product Hunt 每日热榜 | 2025-12-25
人工智能·经验分享·深度学习·神经网络·产品运营
数字化脑洞实验室10 分钟前
智能决策时代的核心引擎——决策优化的力量
人工智能·求解器·决策优化
2501_9402778011 分钟前
如何通过ModelEngine的工程化思维搭建企业级数字资产智能问答助手
人工智能