
在数据分析领域,数据通常以两种主要格式存在:长格式(long format)和宽格式(wide format)。长格式数据通常更适合存储和某些统计分析,因为它将不同的变量观测值堆叠在几列中,而通过一个或多个标识符列来区分。宽格式数据则将不同的变量观测值展开为独立的列,每个观测单元(例如本例中的每个数据集)占据一行。
Anscombe四重奏数据集是一个经典的例子,用于说明统计图表的重要性。该数据集最初以长格式加载,其中dataset列标识了四个不同的数据集(I, II, III, IV),而x和y列则包含对应的数据点。我们的目标是将这种长格式数据转换为宽格式,使得每个数据集的x和y值都拥有独立的列,并且列名带有数据集编号的后缀(例如x1, y1, x2, y2等)。
首先,我们加载并查看原始的长格式Anscombe数据:
import seaborn as sns
import pandas as pd
# 加载Anscombe四重奏数据集
anscombe_long = sns.load_dataset("anscombe")
print("原始长格式数据:")
print(anscombe_long.head())输出示例:
原始长格式数据: dataset x y 0 I 10.0 8.04 1 I 8.0 6.95 2 I 13.0 7.58 3 I 9.0 8.81 4 I 11.0 8.33
要将长格式数据转换为所需的宽格式,我们需要两个关键步骤:
下面是实现这一转换的代码:
# 步骤1:为每个数据集内的行生成一个唯一的序列号
# 将序列号作为新列 'g' 添加到DataFrame
df_temp = anscombe_long.assign(g=anscombe_long.groupby('dataset').cumcount())
# 步骤2:使用pivot方法进行数据重塑
# index='g' 表示新DataFrame的行索引将是'g'列
# columns='dataset' 表示新DataFrame的列将由'dataset'列的唯一值构成
# values参数在此处可以省略,因为我们想将'x'和'y'都作为值进行透视
anscombe_wide_intermediate = df_temp.pivot(index='g', columns='dataset')
print("\n中间宽格式数据(带多级列索引):")
print(anscombe_wide_intermediate)输出示例:
中间宽格式数据(带多级列索引): dataset x y dataset I II III IV I II III IV g 0 10.0 10.0 10.0 8.0 8.04 9.14 7.46 6.58 1 8.0 8.0 8.0 8.0 6.95 8.14 6.77 5.76 2 13.0 13.0 13.0 8.0 7.58 8.74 12.74 7.71 ...
可以看到,pivot操作成功地将数据转换为宽格式,但生成了一个多级列索引(MultiIndex),其中第一级是原始的x和y,第二级是数据集的罗马数字标识符。为了达到目标格式(x1, y1, x2, y2等),我们需要进一步处理列名。
转换后的DataFrame具有一个MultiIndex列,这在某些情况下非常有用,但在此场景中,我们希望将列名扁平化为x1, y1等形式。这需要我们将罗马数字转换为对应的阿拉伯数字。
有两种主要方法可以实现这一点:
如果数据集标识符是罗马数字,并且我们希望有一个通用的解决方案,可以使用roman库。
首先,确保你已安装roman库:
pip install roman
然后,应用转换逻辑:
import roman
# 扁平化列名,并将罗马数字转换为阿拉伯数字
# out.columns 是一个MultiIndex,每个元素是一个元组 (原始列名, dataset标识符)
anscombe_wide_final_roman = anscombe_wide_intermediate.copy() # 创建副本避免修改原始中间结果
anscombe_wide_final_roman.columns = [f'{col_type}{roman.fromRoman(dataset_id)}'
for col_type, dataset_id in anscombe_wide_final_roman.columns]
print("\n最终宽格式数据(使用roman库):")
print(anscombe_wide_final_roman)输出示例:
最终宽格式数据(使用roman库):
x1 x2 x3 x4 y1 y2 y3 y4
g
0 10.0 10.0 10.0 8.0 8.04 9.14 7.46 6.58
1 8.0 8.0 8.0 8.0 6.95 8.14 6.77 5.76
2 13.0 13.0 13.0 8.0 7.58 8.74 12.74 7.71
...如果数据集标识符是有限且已知的,或者不是标准的罗马数字,我们可以创建一个映射字典来手动指定转换关系。这种方法更加灵活,因为它不依赖于特定的库,并且可以处理任意的标识符。
# 定义罗马数字到阿拉伯数字的映射字典
dataset_mapping = {'I': 1, 'II': 2, 'III': 3, 'IV': 4}
# 扁平化列名,并使用映射字典进行转换
anscombe_wide_final_map = anscombe_wide_intermediate.copy() # 创建副本
anscombe_wide_final_map.columns = [f'{col_type}{dataset_mapping[dataset_id]}'
for col_type, dataset_id in anscombe_wide_final_map.columns]
print("\n最终宽格式数据(使用映射字典):")
print(anscombe_wide_final_map)输出示例(与方法一相同):
最终宽格式数据(使用映射字典):
x1 x2 x3 x4 y1 y2 y3 y4
g
0 10.0 10.0 10.0 8.0 8.04 9.14 7.46 6.58
1 8.0 8.0 8.0 8.0 6.95 8.14 6.77 5.76
2 13.0 13.0 13.0 8.0 7.58 8.74 12.74 7.71
...本教程展示了如何利用Pandas的强大功能,将长格式数据高效地转换为具有特定列名约定的宽格式数据。通过结合groupby().cumcount()创建唯一的组内索引,然后使用DataFrame.pivot()进行数据重塑,最后通过列表推导式和roman库或自定义映射字典来优化列名,我们能够灵活地满足数据分析和可视化的特定需求。掌握这些数据重塑技术是进行高效数据处理的关键技能之一。
以上就是将Anscombe数据从长格式转换为宽格式的Pandas教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号