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

一 清除数据中恒定不变值

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

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'])
相关推荐
ghie9090几秒前
利用MATLAB实现不同曝光程度图像融合
人工智能·计算机视觉·matlab
benna3 分钟前
多模态知识图谱的构建及在热点新闻事件中的应用
人工智能·知识图谱
AI弟4 分钟前
第13章 迁移学习:让AI学会“举一反三“的艺术
人工智能·机器学习·迁移学习
ccLianLian4 分钟前
MaskCLIP+
人工智能·计算机视觉
艾莉丝努力练剑5 分钟前
【C++:C++11收尾】解构C++可调用对象:从入门到精通,掌握function包装器与bind适配器包装器详解
java·开发语言·c++·人工智能·c++11·右值引用
Allen_LVyingbo7 分钟前
解锁医疗AI新引擎:从数据库与编程语言透视合成数据生成(代码部分)
数据库·人工智能·深度学习·健康医疗
李景琰8 分钟前
Java 25+AI+物联网+区块链融合平台:架构设计与企业级实现
java·人工智能·物联网·区块链
倔强的石头1068 分钟前
循环神经网络(RNN):从序列数据难题到实战落地的完整指南
人工智能·rnn·深度学习
Leinwin8 分钟前
Ignite 2025:Microsoft 365 Copilot 全面升级,引领企业进入自主智能(Agentic AI)新时代
人工智能·microsoft·copilot