
本文将详细介绍如何使用Pandas库中的lreshape函数,将包含重复模式列(如id_mXX和mprice对)的宽格式Excel表格数据,高效地重塑为更易于分析的长格式数据。通过具体的代码示例,我们将展示如何处理此类复杂的数据转换需求,并提供实用的技巧与注意事项。
在数据分析工作中,我们经常会遇到以“宽格式”存储的数据,其中相同类型的信息被分散到多个列中。例如,一个Excel表格可能包含日期列,以及多组重复的ID和价格列,如id_m00、mprice、id_m01、mprice等,这种模式可能重复数十次。
原始数据示例:
| Date | id_m00 | mprice | id_m01 | mprice |
|---|---|---|---|---|
| 01.01.2023 | aa-bb-cc | 12,05 | dd-ee-fr | 8,80 |
| 02.01.2023 | aa-dd-ee | 09,55 | ff-gg-gg | 7,50 |
这种格式不利于进行聚合分析或绘制趋势图。我们的目标是将其转换为“长格式”,使每组ID和价格成为独立的一行,从而得到如下结构:
立即学习“Python免费学习笔记(深入)”;
目标数据格式:
| Date | id | mprice |
|---|---|---|
| 01.01.2023 | aa-bb-cc | 12,05 |
| 02.01.2023 | aa-dd-ee | 09,55 |
| 01.01.2023 | dd-ee-fr | 8,80 |
| 02.01.2023 | ff-gg-gg | 7,50 |
虽然Pandas的melt函数常用于数据透视,但在处理这种具有多个相关列组的复杂重塑时,lreshape函数通常更为直接和高效。melt在处理非唯一列名时可能会产生额外的列或大量的空值,而lreshape则能更好地处理成对的列。
pandas.lreshape函数是专门为处理这种“多列组”重塑问题设计的。它的核心在于通过一个映射字典(reshape_map)来定义如何将旧列分组并转换为新的列。
假设我们有一个名为data.xlsx的Excel文件,内容如上述原始数据示例。我们将使用pandas来读取并重塑它。
首先,确保你已经安装了Pandas库: pip install pandas openpyxl
接下来,我们将直接从Excel文件读取数据并进行重塑。需要注意的是,当Pandas从Excel文件中读取具有相同名称的列时(例如,多个mprice列),它会自动为重复的列名添加后缀(如mprice.1, mprice.2等),这正是lreshape能够识别和配对的关键。
import pandas as pd
# 模拟创建示例Excel文件 (实际应用中你将直接读取现有文件)
# 为了演示方便,我们手动创建一个DataFrame
data = {
'Date': ['01.01.2023', '02.01.2023'],
'id_m00': ['aa-bb-cc', 'aa-dd-ee'],
'mprice': ['12,05', '09,55'],
'id_m01': ['dd-ee-fr', 'ff-gg-gg'],
'mprice.1': ['8,80', '7,50'] # Pandas读取Excel时会自动重命名重复列
}
# 在实际情况中,如果Excel文件中的mprice列名完全相同,Pandas会默认处理为mprice, mprice.1, mprice.2...
# 如果你的Excel文件真的有多个同名列,Pandas读取时会这样处理。
# 这里我们模拟Pandas读取后的DataFrame结构
df = pd.DataFrame(data)
# 将价格列中的逗号替换为小数点,并转换为数值类型
# 注意:这步是根据示例数据中的逗号作为小数分隔符进行的预处理
for col in df.filter(like='price').columns:
df[col] = df[col].str.replace(',', '.', regex=False).astype(float)
print("原始DataFrame结构:")
print(df)
print("\n")
# 使用 lreshape 进行数据重塑
# 1. 读取Excel文件(假设文件名为 'file.xlsx')
# df = pd.read_excel("file.xlsx") # 在实际应用中取消注释此行
# 2. 定义重塑映射
# 'id' 新列将包含所有以 'id_m' 开头的旧列
# 'mprice' 新列将包含所有以 'price' 开头(包括 mprice, mprice.1 等)的旧列
# Pandas的filter(like=...)方法非常适合动态选择这些模式匹配的列
out = pd.lreshape(
df,
{"id": df.filter(like="id_m").columns,
"mprice": df.filter(like="price").columns}
)
print("重塑后的DataFrame:")
print(out)代码解释:
原始DataFrame结构:
Date id_m00 mprice id_m01 mprice.1
0 01.01.2023 aa-bb-cc 12.05 dd-ee-fr 8.80
1 02.01.2023 aa-dd-ee 9.55 ff-gg-gg 7.50
重塑后的DataFrame:
Date id mprice
0 01.01.2023 aa-bb-cc 12.05
1 02.01.2023 aa-dd-ee 9.55
2 01.01.2023 dd-ee-fr 8.80
3 02.01.2023 ff-gg-gg 7.50可以看到,原始的宽格式数据已被成功转换为我们期望的长格式,每一组id和mprice都成为了独立的一行,并且Date列被正确地复制。
通过使用Pandas的lreshape函数,我们可以高效且优雅地解决将复杂宽格式数据(特别是那些具有重复模式列组的数据)重塑为长格式的问题。这种转换对于后续的数据分析、可视化和建模至关重要,它使得数据结构更加规整,易于处理。掌握lreshape的使用,将大大提升你在Python中处理复杂数据重塑任务的能力。
以上就是利用Python Pandas高效重塑复杂Excel表格数据的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号