sklearn的LabelEncoder 遇到新值的解决办法

问题:sklearn的LabelEncoder函数遇到新值报错

sklearn的LabelEncoder函数,在fit结束后,对dataframe数据进行transform的时候,如果遇到了没在fit时编码规则里的新值,会出现代码报错,不同于spark的LabelEncoder碰到新值会给你编成len+1。

解决办法:基于编码规则的修改

1、保存编码字典

复制代码
from sklearn.preprocessing import LabelEncoder

le = preprocessing.LabelEncoder()
le.fit(X)

# label编码其实就是映射的字典,将编码字典保存
le_dict = dict(zip(le.classes_, le.transform(le.classes_)))

2、数据判断

检索单个新项目的标签,如果项目丢失,则将值设置为未知

复制代码
le_dict.get(new_item, 'Unknown')

3、批量检索 Dataframe 列的标签

复制代码
df['col'] = df['col'].apply(lambda x: le_dict.get(x, 'Unknown'))

# 再将新值删除
df = df[df['col'] != 'Unknown']
df['col'] = df['col'].astype(dtype='int64')
相关推荐
charlie114514191几秒前
机器学习概论:一门教计算机如何“不确定地正确”的学问
人工智能·笔记·机器学习·工程实践
喵手2 分钟前
Python爬虫实战:采集行业协会、研究机构等平台的政策文件列表与PDF链接批量收集系统,支持自动下载、分类归档和数据库管理(SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·sqlite持久化存储·采集行业协会、研究机构政策文件·pdf链接采集
凡。。。2962 分钟前
APS概念-EOQ模型
人工智能·制造
FreeBuf_5 分钟前
MEDUSA安全测试工具:集成74种扫描器与180余项AI Agent安全规则
人工智能·安全
迅为电子6 分钟前
迅为iTOP-Hi3403开发板:解锁多目拼接相机的10.4TOPS强“芯”动力,开启4K智能视觉新纪元
人工智能·itop-hi3403开发板·海思hi3403·多目拼接相机
小润nature8 分钟前
MCP Apps 交互式 GUI 完整指南
人工智能
Piar1231sdafa9 分钟前
YOLO11-EfficientRepBiPAN:海军制服军衔智能识别的革命性突破
人工智能·计算机视觉·目标跟踪
杜子不疼.11 分钟前
加载了cpolar的Reader 电子书管理工具远程使用体验
linux·人工智能
智绘前端12 分钟前
GitHub 登录功能开发 SOP
人工智能·typescript·github·reactjs
diediedei12 分钟前
用Pygame开发你的第一个小游戏
jvm·数据库·python