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')
相关推荐
2501_94696147几秒前
极简大气创业融资 PPT 模板,适合路演、项目宣讲
人工智能·排序算法
得一录2 分钟前
AI 语音助手:如何用大模型优化智能语音交互?
人工智能
玄同7652 分钟前
Python 自动发送邮件实战:用 QQ/163 邮箱发送大模型生成的内容
开发语言·人工智能·python·深度学习·机器学习·邮件·邮箱
逸俊晨晖2 分钟前
NVIDIA 4090的8路1080p实时YOLOv8目标检测
人工智能·yolo·目标检测·nvidia
岱宗夫up3 分钟前
神经网络(MLP)在时间序列预测中的实践应用
python
我的xiaodoujiao3 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 46--撰写 README项目说明文档文件
python·学习·测试工具·pytest
Olamyh4 分钟前
【手搓 ReAct Agent:告别框架,回归本质】
人工智能·python
seaside20034 分钟前
大模型计算量、显存计算方法推导
人工智能·大模型
AI资源库5 分钟前
nvidiapersonaplex-7b-v1模型深入解析
人工智能·语言模型·回归
数研小生7 分钟前
Python自然语言处理:NLTK与Gensim库
开发语言·python·自然语言处理