news 2026/3/22 20:35:09

one-hot编码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
one-hot编码

我来详细介绍一下one-hot 编码(独热编码)。

什么是 One-Hot 编码?

One-Hot 编码是一种将分类变量转换为二进制向量的技术,其中每个类别都表示为一个二进制向量,只有一个元素为1("热"),其余都为0。

工作原理

假设有一个颜色类别变量:["红", "绿", "蓝"]

原始数据:

text

红 绿 蓝 红

One-Hot 编码后:

text

红 → [1, 0, 0] 绿 → [0, 1, 0] 蓝 → [0, 0, 1] 红 → [1, 0, 0]

为什么要使用 One-Hot 编码?

  1. 消除类别间的序数关系:避免机器学习模型误以为类别之间有大小顺序关系

  2. 兼容算法:许多机器学习算法(如线性回归、神经网络)需要数值输入

  3. 保持类别独立性:每个类别都成为独立的特征维度

在 Python 中的实现

方法1:使用 pandas

python

import pandas as pd # 创建示例数据 df = pd.DataFrame({'颜色': ['红', '绿', '蓝', '红', '绿']}) # 进行 one-hot 编码 one_hot = pd.get_dummies(df['颜色'], prefix='颜色') print(one_hot)

方法2:使用 scikit-learn

python

from sklearn.preprocessing import OneHotEncoder import numpy as np # 创建示例数据 data = np.array(['红', '绿', '蓝', '红', '绿']).reshape(-1, 1) # 创建编码器 encoder = OneHotEncoder(sparse_output=False) # 拟合和转换 one_hot_encoded = encoder.fit_transform(data) print(one_hot_encoded)

One-Hot 编码的优缺点

优点:

  • ✅ 简单直观,易于实现

  • ✅ 消除了类别间的虚假序数关系

  • ✅ 与大多数机器学习算法兼容

缺点:

  • 维度灾难:如果类别很多,会创建大量稀疏特征

  • 稀疏矩阵:存储效率低

  • ❌ 丢失了类别之间的关系信息(如果有的话)

替代方案

  1. 标签编码(Label Encoding):将类别转换为数字(0, 1, 2...)

  2. 目标编码(Target Encoding):用目标变量的统计量编码

  3. 二进制编码(Binary Encoding):将类别先转换为数字,再转换为二进制

实用建议

  • 当类别数量较少(如<15)时,使用 One-Hot 编码

  • 当类别数量很多时,考虑其他编码方式或特征选择

  • 在神经网络中,One-Hot 编码通常用于输入层

  • 对于有序类别,可以考虑使用有序编码而不是 One-Hot

示例:完整代码

python

import pandas as pd from sklearn.model_selection import train_test_split from sklearn.linear_model import LogisticRegression # 示例数据 data = pd.DataFrame({ '颜色': ['红', '绿', '蓝', '红', '绿', '蓝'], '尺寸': ['大', '中', '小', '中', '大', '小'], '价格': [100, 200, 150, 120, 180, 160] }) # One-Hot 编码分类变量 data_encoded = pd.get_dummies(data, columns=['颜色', '尺寸']) print("原始数据:") print(data) print("\nOne-Hot 编码后:") print(data_encoded)

One-Hot 编码是数据预处理中的基础且重要的技术,特别适用于处理名义型分类变量。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/17 5:34:50

Java计算机毕设之基于springboot+vue的食品仓库管理系统的设计与实现(完整前后端代码+说明文档+LW,调试定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/3/12 22:28:06

windows clion 更新 MinGW 的工具链

说明 windows 版本的 CLion 2025.2.4&#xff0c;打算更新 MinGW 的默认工具链&#xff08;C 与 C 的编译工具链&#xff09; 下载 MinGW 的工具链 地址 https://github.com/niXman/mingw-builds-binaries/releases/tag/15.2.0-rt_v13-rev0&#xff0c;这里下载 x86_64-15.2…

作者头像 李华
网站建设 2026/3/21 0:05:49

【计算机毕业设计案例】基于springboot的在线招标系统的设计与实现构建 “招标管理 - 投标响应 - 开标评标 - 结果公示 - 档案归档” 一体化平台(程序+文档+讲解+定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/3/12 19:40:20

python多表关联防注入sql

# 1. 待删除的多个参数&#xff08;业务传入&#xff09; oenum_list ["OE123", "OE456"] start_time "2025-01-01 00:00:00" # 新增参数1&#xff1a;时间阈值 status 0 # 新增参数2&#xff1a;状态值# 2. 多参数…

作者头像 李华