
在数据分析工作中,我们经常会遇到宽格式(wide format)的数据表,其中包含大量重复模式的列组。例如,一个excel表格可能包含多组产品id和价格信息,如id_m00, mprice, id_m01, mprice, ..., 直到id_m46, mprice。这种格式虽然在某些情况下便于录入,但在进行数据分析和建模时,通常需要将其转换为长格式(long format),即每行代表一个独立的观测值,将所有重复的id和价格信息归并到两列:id和mprice。
传统的pandas.melt函数在处理这类复杂重塑时,可能会因为其设计逻辑而产生额外的variable列或大量的空值,导致后续清理工作量大。针对这种具有明确“成对”或“分组”列的重塑需求,pandas.lreshape提供了一种更为高效和简洁的解决方案。
pandas.lreshape函数专门用于处理那些具有列表状(list-like)分组列的数据重塑。它的核心思想是将一组列(例如id_m00, id_m01)映射到一个新的列名(id),同时将另一组对应的列(例如mprice, mprice.1)映射到另一个新的列名(mprice),从而实现数据的垂直堆叠。
主要参数:
假设我们有如下的宽格式Excel数据(data.xlsx):
立即学习“Python免费学习笔记(深入)”;
| 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 |
我们的目标是将其转换为:
| 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 |
准备模拟数据:
import pandas as pd
import io
# 模拟原始Excel数据,实际应用中替换为 pd.read_excel("file.xlsx")
data = """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,9.55,ff-gg-gg,7.50
"""
# 注意:当Pandas读取Excel时,如果存在重复列名,会自动重命名为 mprice, mprice.1, mprice.2 等
# 这里为了模拟,我们手动创建DataFrame,并模拟Pandas的列名处理
df_raw = pd.read_csv(io.StringIO(data), sep=',')
# 模拟pandas读取Excel后,重复列名被自动重命名的情况
# 手动调整列名以匹配 lreshape 示例中的 mprice, mprice.1
df_raw.columns = ['Date', 'id_m00', 'mprice', 'id_m01', 'mprice.1']
print("原始DataFrame:")
print(df_raw)使用lreshape进行重塑:
lreshape的关键在于构建reshape_map。我们需要识别出所有属于“id”组的列和所有属于“mprice”组的列。由于Pandas在读取Excel时会自动处理重复列名(如将第二个mprice重命名为mprice.1),我们可以利用这一特性来简化列的选择。
# 方案一:直接使用filter选择列(推荐)
# 假设df是通过pd.read_excel("file.xlsx")读取的,Pandas会自动处理重复列名
# 此时,mprice列会变为 'mprice', 'mprice.1', 'mprice.2' ...
# df = pd.read_excel("file.xlsx") # 实际应用中取消注释
# 识别所有id_mXX开头的列
id_cols = df_raw.filter(like="id_m").columns
# 识别所有包含'price'的列(这里会包含mprice和mprice.1等)
price_cols = df_raw.filter(like="price").columns
# 构建lreshape的映射字典
reshape_map = {
"id": id_cols.tolist(),
"mprice": price_cols.tolist()
}
out_df = pd.lreshape(df_raw, reshape_map)
print("\n重塑后的DataFrame (方案一):")
print(out_df)
# 确保mprice列为数值类型
out_df['mprice'] = out_df['mprice'].astype(float)
print("\n重塑后并转换mprice类型:")
print(out_df)代码解析:
通过pandas.lreshape,我们可以高效、准确地将复杂的宽格式数据转换为规范的长格式,这对于后续的数据清洗、分析和可视化至关重要,能够显著提升数据处理的效率和质量。
以上就是Python Pandas:高效重塑Excel宽表数据为规范长表格式的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号