
在数据分析和处理中,我们经常会遇到需要改变数据结构以适应特定分析工具或可视化需求的场景。其中一个常见的需求是将“宽格式”数据转换为“长格式”数据。宽格式数据通常意味着某些类别信息分散在多个列中,而长格式数据则将这些类别信息和对应的值聚合到少数几个列中。
考虑一个典型的世界银行数据集,其中包含了不同年份的指标数据。原始数据可能呈现为宽格式:
当前数据结构示例 (宽格式):
| 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 |
Pandas库提供了强大的melt()函数,专门用于将DataFrame从宽格式重塑为长格式。这个函数的核心思想是将一个或多个列“unpivot”(非枢轴化),即将这些列的列名转换为新的一列中的值,并将这些列中的数据转换为另一列中的值。
melt()函数的主要参数包括:
下面我们将通过一个具体的Python示例来演示如何使用melt()函数实现上述数据转换。
首先,我们创建一个模拟的原始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代码解析:
通过上述操作,我们成功将宽格式的世界银行数据转换为长格式,使得年份和通货膨胀值都成为独立的列,极大地简化了后续的数据分析和可视化流程。
pandas.melt()函数是数据预处理中一个极其有用的工具,尤其在处理时间序列数据或需要将多列指标转换为统一格式进行分析时。通过合理配置id_vars、value_vars、var_name和value_name参数,可以高效地将宽格式数据转换为更易于管理和分析的长格式数据,从而为后续的数据探索、建模和可视化奠定坚实基础。掌握melt()的使用,能够显著提升数据处理的效率和灵活性。
以上就是Pandas数据重塑:利用melt()函数将宽格式时间序列数据转换为长格式的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号