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

DDD
发布: 2025-10-08 10:31:28
原创
794人浏览过

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。

文心快码
文心快码

文心快码(Comate)是百度推出的一款AI辅助编程工具

文心快码 35
查看详情 文心快码

这是修改后的代码示例:

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 参数。

以上就是Pandas get_dummies:独热编码输出0和1而非布尔值的正确姿势的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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