0

0

Pandas get_dummies:独热编码输出0和1而非布尔值的正确姿势

DDD

DDD

发布时间:2025-10-08 10:31:28

|

893人浏览过

|

来源于php中文网

原创

Pandas get_dummies:独热编码输出0和1而非布尔值的正确姿势

本文深入探讨了Pandas pd.get_dummies 在执行独热编码时,默认返回布尔值(True/False)而非二进制0和1的原因。通过介绍 dtype 参数,教程将指导用户如何简单地将输出强制转换为整数0和1,确保数据符合机器学习模型或其他数值处理的需求,从而避免常见的编码困惑。

在数据预处理阶段,独热编码(one-hot encoding)是处理分类特征的常用技术,它将类别变量转换为数值型,以便机器学习算法能够理解和处理。pandas库提供了 pd.get_dummies 函数,极大地简化了这一过程。然而,许多用户在使用时会发现,其默认输出是布尔值 true 和 false,而非期望的二进制 0 和 1,这在后续数据处理或模型训练中可能引发问题。

理解 pd.get_dummies 的默认行为

pd.get_dummies 函数的核心作用是将DataFrame中的分类列转换为独热编码表示。对于每个唯一的类别值,它会创建一个新的列,并在原始行中对应类别出现的位置标记为 True,其他位置为 False。这种设计在某些场景下是合理的,例如在需要布尔掩码或进行逻辑判断时。然而,当我们需要将这些编码后的特征作为数值输入(例如,许多机器学习模型期望数值型特征)时,True 和 False 的布尔值就显得不那么直观或方便了。

让我们通过一个简单的例子来观察这种默认行为:

import pandas as pd

# 原始DataFrame
data = {'category': ['A', 'B', 'A', 'C'],
        'value': [10, 20, 30, 40]}
df = pd.DataFrame(data)
print("原始DataFrame:")
print(df)

# 默认使用get_dummies进行独热编码
df_encoded_default = pd.get_dummies(df, columns=['category'])
print("\n默认get_dummies输出 (布尔值):")
print(df_encoded_default)
print("\n默认输出列的数据类型:")
print(df_encoded_default.dtypes)

运行上述代码,你会发现 category_A, category_B, category_C 等新生成的列的数据类型是 bool,并且值是 True 或 False。

强制输出0和1的解决方案:使用 dtype 参数

为了解决 pd.get_dummies 默认输出布尔值的问题,Pandas提供了一个名为 dtype 的参数。通过将 dtype 参数设置为 int 或 float,我们可以强制 pd.get_dummies 将生成的独热编码列的数据类型设置为整数或浮点数,从而将 True 转换为 1,False 转换为 0。

Cutout.Pro
Cutout.Pro

AI驱动的视觉设计平台

下载

这是修改后的代码示例:

import pandas as pd

# 原始DataFrame
data = {'category': ['A', 'B', 'A', 'C'],
        'value': [10, 20, 30, 40]}
df = pd.DataFrame(data)

# 使用dtype=int强制输出0和1
df_encoded_int = pd.get_dummies(df, columns=['category'], dtype=int)
print("\n使用dtype=int的get_dummies输出 (0和1):")
print(df_encoded_int)
print("\n强制输出0和1后列的数据类型:")
print(df_encoded_int.dtypes)

通过简单地添加 dtype=int 参数,我们可以清晰地看到 category_A, category_B, category_C 等列现在的数据类型是 int64,并且值是 0 或 1。

注意事项与最佳实践

  1. dtype 参数的灵活性: 除了 int,你还可以将 dtype 设置为 float (例如 dtype=float),这将使输出为 0.0 和 1.0。选择 int 还是 float 通常取决于下游任务的需求。对于大多数机器学习模型,int 类型的 0 和 1 已经足够。
  2. 默认行为的考量: Pandas之所以默认输出布尔值,可能是出于内存效率和某些内部操作的优化考虑。布尔值在内存中通常比整数占用更少的空间。然而,对于大多数数据分析和机器学习场景,转换为 int 或 float 的开销通常可以忽略不计。
  3. 何时需要0和1:
    • 机器学习模型输入: 绝大多数机器学习库(如Scikit-learn、TensorFlow、PyTorch)在处理特征时期望数值型输入。布尔值虽然在Python中可以隐式转换为0/1,但显式地将其转换为整数可以避免潜在的类型不匹配问题,并提高代码的清晰度。
    • 与其他数值数据合并: 当独热编码后的列需要与DataFrame中的其他数值列进行数学运算(如求和、乘积)或合并时,统一的数据类型会使操作更加顺畅。
    • 数据导出: 在将数据导出到CSV或其他格式时,确保数值型输出可以避免在其他系统或软件中解析布尔值时可能出现的问题。

总结

pd.get_dummies 是Pandas中一个功能强大的独热编码工具。理解其默认输出布尔值的行为,并掌握如何通过 dtype=int 参数强制输出二进制 0 和 1,是数据预处理中的一个重要技能。通过这一简单的参数调整,可以确保独热编码后的数据类型符合后续分析和模型训练的需求,避免不必要的困惑和错误,从而提升数据处理的效率和准确性。在进行独热编码时,请务必根据你的具体应用场景,合理选择 dtype 参数。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

68

2025.12.04

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

309

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

580

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

102

2025.10.23

css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

580

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

102

2025.10.23

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号