get_dumines() 函数,用于将分类变量转换为哑变量

1. get_dummies() 函数的基本用法

get_dummies() 函数可以将DataFrame中的分类变量(通常是字符串类型)转换为哑变量,每个类别对应一个哑变量列,其中包含1和0的值,表示该类别是否出现。

python 复制代码
import pandas as pd

# 创建一个包含分类变量的DataFrame
df = pd.DataFrame({
    'color': ['red', 'blue', 'green', 'blue'],
    'shape': ['circle', 'square', 'circle', 'triangle']
})

# 使用get_dummies()转换分类变量
dummies = pd.get_dummies(df, columns=['color', 'shape'])
print(dummies)

2. 处理缺失值

在使用 get_dummies() 之前,您需要决定如何处理DataFrame中的缺失值。以下是几种处理缺失值的方法:

  1. 删除包含缺失值的行

    如果数据集中的缺失值不多,可以选择删除这些行。

    python 复制代码
    df = df.dropna()
  2. 填充缺失值

    如果删除缺失值会导致数据量大幅减少,可以选择填充这些缺失值。填充策略可以是填充为最常见的值、中位数、众数或者一个特定的值。

    python 复制代码
    df['column'] = df['column'].fillna('missing')
  3. get_dummies() 中处理缺失值
    get_dummies() 函数允许您指定如何处理缺失值。例如,您可以将缺失值视为一个单独的类别。

    python 复制代码
    dummies = pd.get_dummies(df, columns=['color', 'shape'], dummy_na=True)

3. 示例代码

以下是一个完整的示例,展示了如何在处理缺失值后使用 get_dummies() 函数:

python 复制代码
import pandas as pd

# 创建一个包含缺失值的DataFrame
df = pd.DataFrame({
    'color': ['red', 'blue', None, 'blue'],
    'shape': ['circle', 'square', 'circle', None]
})

# 填充缺失值
df['color'].fillna('unknown', inplace=True)
df['shape'].fillna('unknown', inplace=True)

# 使用get_dummies()转换分类变量
dummies = pd.get_dummies(df, columns=['color', 'shape'])
print(dummies)

输出结果:

sql 复制代码
   color_blue  color_red  color_unknown  shape_circle  shape_square  shape_unknown
0           0         1              0            1            0             0
1           1         0              0            0            1             0
2           0         0              1            1            0             0
3           1         0              0            0            0             1

在这个结果中:

color_blue、color_red 和 color_unknown 是从 color 列生成的哑变量列,分别表示颜色为蓝色、红色和未知的颜色。

shape_circle、shape_square 和 shape_unknown 是从 shape 列生成的哑变量列,分别表示形状为圆形、正方形和未知的形状。

每一列中的1表示对应的类别在该行中出现,0表示没有出现。这样,您就可以使用这些哑变量进行进一步的数据分析或机器学习建模了。

在这个示例中,我们首先填充了缺失值,然后使用 get_dummies() 函数将分类变量转换为哑变量。这样可以确保在转换过程中不会丢失任何信息。希望这次的解释更加清晰,并且能够帮助您正确使用 get_dummies() 函数。

将分类标签转换为模型可以处理的数值格式

相关推荐
AI医影跨模态组学2 分钟前
如何将纵向MRI深度学习特征与局部晚期直肠癌新辅助放化疗后的免疫微环境建立关联,并解释其对pCR及预后的机制
人工智能·深度学习·论文·医学·医学影像·影像组学
Empty-Filled3 分钟前
AI生成测试用例功能怎么测:一个完整实战案例
网络·人工智能·测试用例
eastyuxiao4 分钟前
设计一个基于 OpenClaw 的 AI 智能体来辅助交易
人工智能
波动几何34 分钟前
因果动力学架构技能cda
人工智能
Lucas_coding36 分钟前
【Claude Code Router】 Claude Code 兼容 OpenAI 格式 API, Claude code 接入本地部署模型
人工智能·python
jinanwuhuaguo38 分钟前
(第二十七篇)OpenClaw四月的演化风暴:OpenClaw 2026年4月全版本更新的文明级解读
大数据·人工智能·架构·kotlin·openclaw
测试员周周40 分钟前
【AI测试系统】第5篇:从 Archon 看 AI 工程化落地:为什么"确定性编排+AI 弹性智能"是终局?
人工智能·python·测试
RxGc1 小时前
微软AI Agent框架深度测评:Microsoft Agent Framework 1.0 vs OpenClaw/Claude企业级能力对比
人工智能·agent
随便写写1 小时前
第四章 智能体经典范式构建
人工智能
穿过生命散发芬芳1 小时前
基于CodeBuddy Agent智能体平台构建自己第一个SKILL——相机推荐
人工智能