0

0

Pandas数据重塑:利用melt()函数将宽格式时间序列数据转换为长格式

聖光之護

聖光之護

发布时间:2025-10-07 12:06:21

|

468人浏览过

|

来源于php中文网

原创

Pandas数据重塑:利用melt()函数将宽格式时间序列数据转换为长格式

本教程详细介绍了如何使用Pandas库中的melt()函数,将常见的宽格式数据集(如以年份作为列的世界银行数据)高效地转换为更适合分析和可视化的长格式数据。通过具体的代码示例和参数解析,读者将学会如何将分散在多个列中的值聚合到一个新列中,并为原列名创建一个对应的标识列,从而实现数据结构的优化。

在数据分析和处理中,我们经常会遇到需要改变数据结构以适应特定分析工具或可视化需求的场景。其中一个常见的需求是将“宽格式”数据转换为“长格式”数据。宽格式数据通常意味着某些类别信息分散在多个列中,而长格式数据则将这些类别信息和对应的值聚合到少数几个列中。

1. 理解宽格式与长格式数据

考虑一个典型的世界银行数据集,其中包含了不同年份的指标数据。原始数据可能呈现为宽格式:

当前数据结构示例 (宽格式):

TOPIC COVENTRY CODE CURRENCY 2000 2001 2002 2003
Inflatio United Kingdom UK GBP x x x x

这种格式在某些情况下可能难以直接进行时间序列分析或绘制趋势图,因为年份作为列名而不是一个独立的变量。

我们的目标是将其转换为长格式,使得每一年份的数据都作为独立的一行,并新增一个“年份”列和一个“指标值”列:

期望数据结构示例 (长格式):

COVENTRY CODE CURRENCY YEAR INFLATION
United Kingdom UK GBP 2000 x
United Kingdom UK GBP 2001 x
United Kingdom UK GBP 2002 x
United Kingdom UK GBP 2003 x

2. 使用 Pandas melt() 函数进行数据重塑

Pandas库提供了强大的melt()函数,专门用于将DataFrame从宽格式重塑为长格式。这个函数的核心思想是将一个或多个列“unpivot”(非枢轴化),即将这些列的列名转换为新的一列中的值,并将这些列中的数据转换为另一列中的值。

melt()函数的主要参数包括:

  • id_vars: 一个列表,包含不进行非枢轴化的标识符列。这些列将保持不变,并在结果DataFrame中重复出现。
  • value_vars: 一个列表,包含需要进行非枢轴化的值列。这些列的列名将成为新变量列的值,其对应的值将成为新值列的值。如果省略,则除了id_vars之外的所有列都将被视为value_vars。
  • var_name: 一个字符串,用于指定新创建的变量列的名称(该列将包含原value_vars的列名)。
  • value_name: 一个字符串,用于指定新创建的值列的名称(该列将包含原value_vars的值)。

3. 示例代码与解析

下面我们将通过一个具体的Python示例来演示如何使用melt()函数实现上述数据转换。

Quinvio AI
Quinvio AI

AI辅助下快速创建视频,虚拟代言人

下载

首先,我们创建一个模拟的原始DataFrame:

import pandas as pd

# 创建原始的宽格式DataFrame
data = {
    "TOPIC": ["Inflatio"],
    "COVENTRY": ["United Kingdom"],
    "CODE": ["UK"],
    "CURRENCY": ["GBP"],
    "2000": ["x_2000"],
    "2001": ["x_2001"],
    "2002": ["x_2002"],
    "2003": ["x_2003"]
}
df = pd.DataFrame(data)

print("原始DataFrame:")
print(df)

原始DataFrame输出:

原始DataFrame:
      TOPIC        COVENTRY CODE CURRENCY    2000    2001    2002    2003
0  Inflatio  United Kingdom   UK      GBP  x_2000  x_2001  x_2002  x_2003

接下来,使用melt()函数进行数据重塑:

# 定义作为标识符的列
id_columns = ["TOPIC", "COVENTRY", "CODE", "CURRENCY"]

# 定义需要非枢轴化的年份列
value_columns = ["2000", "2001", "2002", "2003"]

# 使用melt()函数进行数据重塑
out = df.melt(
    id_vars=id_columns,
    value_vars=value_columns,
    var_name='YEAR',        # 新的变量列名称
    value_name="INFLATION"  # 新的值列名称
)

print("\n重塑后的DataFrame:")
print(out)

重塑后的DataFrame输出:

重塑后的DataFrame:
      TOPIC        COVENTRY CODE CURRENCY  YEAR INFLATION
0  Inflatio  United Kingdom   UK      GBP  2000    x_2000
1  Inflatio  United Kingdom   UK      GBP  2001    x_2001
2  Inflatio  United Kingdom   UK      GBP  2002    x_2002
3  Inflatio  United Kingdom   UK      GBP  2003    x_2003

代码解析:

  1. id_vars=id_columns: 我们指定"TOPIC", "COVENTRY", "CODE", "CURRENCY"这些列作为标识符。它们在重塑过程中不会被改变,其值会在结果DataFrame中根据需要重复。
  2. value_vars=value_columns: 我们指定"2000", "2001", "2002", "2003"这些列是需要被“融化”的列。它们的列名将成为新YEAR列的值,它们各自单元格中的数据将成为新INFLATION列的值。
  3. var_name='YEAR': 指定将原value_vars的列名(即"2000", "2001"等)聚合到的新列的名称为'YEAR'。
  4. value_name="INFLATION": 指定将原value_vars中的数据聚合到的新列的名称为'INFLATION'。

通过上述操作,我们成功将宽格式的世界银行数据转换为长格式,使得年份和通货膨胀值都成为独立的列,极大地简化了后续的数据分析和可视化流程。

4. 注意事项与最佳实践

  • 选择正确的id_vars和value_vars: 这是melt()函数最关键的部分。id_vars应包含所有你希望保持不变的识别信息,而value_vars则应包含所有你希望“非枢轴化”的列。
  • 数据类型: melt()函数默认会将value_vars中的所有值转换为一个共同的数据类型(通常是字符串或对象),以容纳所有可能的值。重塑后,你可能需要对新生成的YEAR或INFLATION列进行类型转换(例如,将YEAR从字符串转换为整数,如果它们代表年份)。
  • 与pivot_table()的关系: melt()和pivot_table()(或pivot())是互补的操作。melt()将宽格式转换为长格式(unpivot),而pivot_table()将长格式转换为宽格式(pivot)。
  • 性能: 对于大型数据集,melt()的性能通常很高,因为它是由Pandas底层优化过的操作。

5. 总结

pandas.melt()函数是数据预处理中一个极其有用的工具,尤其在处理时间序列数据或需要将多列指标转换为统一格式进行分析时。通过合理配置id_vars、value_vars、var_name和value_name参数,可以高效地将宽格式数据转换为更易于管理和分析的长格式数据,从而为后续的数据探索、建模和可视化奠定坚实基础。掌握melt()的使用,能够显著提升数据处理的效率和灵活性。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

772

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

661

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

679

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1365

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

569

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

730

2023.08.11

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

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

精品课程

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

共4课时 | 13.8万人学习

Django 教程
Django 教程

共28课时 | 3.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.2万人学习

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

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