利用Python Pandas高效重塑复杂Excel表格数据

利用python pandas高效重塑复杂excel表格数据

本文将详细介绍如何使用Pandas库中的lreshape函数,将包含重复模式列(如id_mXX和mprice对)的宽格式Excel表格数据,高效地重塑为更易于分析的长格式数据。通过具体的代码示例,我们将展示如何处理此类复杂的数据转换需求,并提供实用的技巧与注意事项。

理解数据重塑的需求

在数据分析工作中,我们经常会遇到以“宽格式”存储的数据,其中相同类型的信息被分散到多个列中。例如,一个Excel表格可能包含日期列,以及多组重复的ID和价格列,如id_m00、mprice、id_m01、mprice等,这种模式可能重复数十次。

原始数据示例:

Date id_m00 mprice id_m01 mprice

01.01.2023aa-bb-cc12,05dd-ee-fr8,8002.01.2023aa-dd-ee09,55ff-gg-gg7,50

这种格式不利于进行聚合分析或绘制趋势图。我们的目标是将其转换为“长格式”,使每组ID和价格成为独立的一行,从而得到如下结构:

立即学习“Python免费学习笔记(深入)”;

目标数据格式:

Date id mprice

01.01.2023aa-bb-cc12,0502.01.2023aa-dd-ee09,5501.01.2023dd-ee-fr8,8002.01.2023ff-gg-gg7,50

虽然Pandas的melt函数常用于数据透视,但在处理这种具有多个相关列组的复杂重塑时,lreshape函数通常更为直接和高效。melt在处理非唯一列名时可能会产生额外的列或大量的空值,而lreshape则能更好地处理成对的列。

Pandas lreshape:高效解决方案

pandas.lreshape函数是专门为处理这种“多列组”重塑问题设计的。它的核心在于通过一个映射字典(reshape_map)来定义如何将旧列分组并转换为新的列。

lreshape函数的核心参数

data: 需要重塑的DataFrame。reshape_map: 一个字典,键是新列的名称,值是一个列表,包含所有将合并到该新列的旧列名称。lreshape会根据这些列表的顺序进行配对。

实战应用:重塑Excel数据

假设我们有一个名为data.xlsx的Excel文件,内容如上述原始数据示例。我们将使用pandas来读取并重塑它。

首先,确保你已经安装了Pandas库:pip install pandas openpyxl

接下来,我们将直接从Excel文件读取数据并进行重塑。需要注意的是,当Pandas从Excel文件中读取具有相同名称的列时(例如,多个mprice列),它会自动为重复的列名添加后缀(如mprice.1, mprice.2等),这正是lreshape能够识别和配对的关键。

import pandas as pd# 模拟创建示例Excel文件 (实际应用中你将直接读取现有文件)# 为了演示方便,我们手动创建一个DataFramedata = {    '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来模拟从Excel读取的数据。实际应用中,你只需要使用df = pd.read_excel(“your_file.xlsx”)来读取你的Excel文件。请注意,Pandas在读取Excel时会自动处理重复的列名(例如,将第二个mprice列重命名为mprice.1),这正是lreshape能够正常工作的基础。数据类型转换: 原始数据中的价格使用了逗号作为小数分隔符。在进行数值计算前,我们将其替换为小数点并转换为浮点型。pd.lreshape(df, reshape_map): 这是核心操作。df: 我们要操作的DataFrame。{“id”: df.filter(like=”id_m”).columns, “mprice”: df.filter(like=”price”).columns}: 这是reshape_map字典。”id”: df.filter(like=”id_m”).columns: 表示新的id列将由所有名称中包含”id_m”的原始列(如id_m00, id_m01等)构成。”mprice”: df.filter(like=”price”).columns: 表示新的mprice列将由所有名称中包含”price”的原始列(如mprice, mprice.1等)构成。lreshape会根据reshape_map中列表的顺序,将这些匹配到的列进行配对,并将其值合并到新的id和mprice列中。例如,id_m00会与第一个mprice配对,id_m01会与mprice.1配对,以此类推。

输出结果

原始DataFrame结构:         Date    id_m00 mprice    id_m01  mprice.10  01.01.2023  aa-bb-cc  12.05  dd-ee-fr      8.801  02.01.2023  aa-dd-ee   9.55  ff-gg-gg      7.50重塑后的DataFrame:         Date        id  mprice0  01.01.2023  aa-bb-cc   12.051  02.01.2023  aa-dd-ee    9.552  01.01.2023  dd-ee-fr    8.803  02.01.2023  ff-gg-gg    7.50

可以看到,原始的宽格式数据已被成功转换为我们期望的长格式,每一组id和mprice都成为了独立的一行,并且Date列被正确地复制。

注意事项与最佳实践

列名的一致性: lreshape的强大之处在于它能够根据列名的模式进行自动配对。因此,确保你的原始数据中,需要重塑的列名遵循一致的命名模式(如id_mXX和mprice系列),这样df.filter(like=…)才能准确地选择它们。Pandas读取Excel时的列名处理: 当Excel文件中存在多个同名列时,Pandas的read_excel函数会自动为重复的列名添加数字后缀(例如mprice, mprice.1, mprice.2等)。lreshape正是利用了这一点来进行正确的列配对。如果你手动创建DataFrame或从其他源加载数据,需要确保这些重复列的名称是唯一的,或者手动进行重命名以模拟read_excel的行为。lreshape与melt的选择:选择lreshape: 当你需要将多组相关联的列(例如,id_X与value_X总是成对出现)重塑为少数几列时,lreshape是理想选择。它能确保这些成对关系在重塑后得到保持。选择melt: 当你只需要将一系列不相关的“值”列转换为一个“值”列和一个“变量”列时,melt更适用。它通常用于将一个或多个标识符列(id_vars)保持不变,然后将其他所有列(或指定的value_vars)堆叠起来。数据类型: 在重塑前,确保你的数据类型是正确的。例如,价格列可能需要从字符串转换为数值类型,以避免后续计算错误。

总结

通过使用Pandas的lreshape函数,我们可以高效且优雅地解决将复杂宽格式数据(特别是那些具有重复模式列组的数据)重塑为长格式的问题。这种转换对于后续的数据分析、可视化和建模至关重要,它使得数据结构更加规整,易于处理。掌握lreshape的使用,将大大提升你在Python中处理复杂数据重塑任务的能力。

以上就是利用Python Pandas高效重塑复杂Excel表格数据的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1363104.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 03:13:00
下一篇 2025年12月14日 03:13:14

相关推荐

  • Python字符编码修复:巧用raw_unicode_escape解决特定编码错位问题

    本文深入探讨在Python中处理特定字符编码错误的问题,尤其当一个Unicode字符实际上是另一编码下某个字节的错误解读时。针对例如将ø(Unicode U+00F8)纠正为ř(Windows-1250 0xF8)的场景,文章详细介绍了如何利用raw_unicode_escape编码将Unicode…

    2025年12月14日
    000
  • Python中如何实现加密解密?hashlib模块详解

    hashlib是python标准库中的模块,用于生成数据的哈希值,属于单向散列算法,不能用于加密解密。其主要用途包括密码存储、文件校验等。1. 哈希算法如sha-256可用于生成字符串或文件的指纹;2. 使用时需将输入转为字节类型,并通过hexdigest()获取结果;3. 大文件可通过分块读取并调…

    2025年12月14日 好文分享
    000
  • 怎样用Python开发物联网应用?MQTT协议实践

    用python开发物联网应用结合mqtt协议的核心在于使用paho-mqtt库实现设备间高效通信。1. 安装paho-mqtt库,通过pip install paho-mqtt完成依赖准备;2. 编写发布者代码连接mqtt broker并周期性发送模拟传感器数据;3. 编写订阅者代码接收并处理发布者…

    2025年12月14日 好文分享
    000
  • Python如何实现数据加密?hashlib模块应用

    hashlib模块不可逆,适用于数据完整性校验、密码存储或数字签名,但不适用于需要解密的加密场景。1. hashlib提供单向哈希功能,用于生成固定长度的哈希值,无法还原原始数据;2. 常见应用场景包括密码存储(存储哈希而非明文)、文件完整性校验;3. 对于需要解密的数据加密,应使用secrets模…

    2025年12月14日 好文分享
    000
  • 怎样用Python实现数据模拟?随机生成方案

    使用python进行数据模拟可通过不同工具实现,根据需求选择合适方法。1.基础随机数可用random模块,如生成随机整数、浮点数或从列表中选元素;2.复杂真实数据推荐faker库,支持生成姓名、地址、邮箱等结构化信息,并可指定语言地区;3.时间序列与分布数据借助numpy和pandas,可创建正态或…

    2025年12月14日 好文分享
    000
  • 如何使用Python处理图片?PIL库进阶技巧

    pil高效处理大尺寸图像需掌握五项策略:尽早缩放、利用延迟加载、分块处理、及时释放资源、调整像素限制。首先,使用thumbnail()或resize()在加载后立即缩小图片,避免全图解码;其次,pil的image.open()不会立即加载全部像素,仅在操作时才会加载,应避免不必要的load()调用;…

    2025年12月14日 好文分享
    000
  • 在 Amazon Linux 2023 上安装 Python 的强化版 pip

    本文旨在指导用户如何在 Amazon Linux 2023 上安装与系统自带 Python 版本对应的强化版 pip 包。通过安装系统提供的 python3-pip 包,确保使用的 pip 版本与系统环境兼容,并遵循 Amazon Linux 2023 的支持路径,避免潜在的兼容性问题。 在 Ama…

    2025年12月14日
    000
  • 在 Amazon Linux 2023 上安装安全增强的 pip

    在 Amazon Linux 2023 上,为了确保系统的安全性和稳定性,建议尽可能使用官方提供的软件包。 本文将介绍如何在 Amazon Linux 2023 上安装与系统自带 Python 版本对应的 pip 包,从而避免使用未经验证的第三方安装方式。 Amazon Linux 2023 预装了…

    2025年12月14日
    000
  • 在 Amazon Linux 2023 上安装强化版 Python pip

    本文将介绍如何在 Amazon Linux 2023 上安装强化版 Python pip。正如摘要所述,我们将通过安装 python3-pip 包,使用官方支持且经过强化的 pip 版本。 Amazon Linux 2023 默认包含 Python,但并未预装 pip。 为了获得与系统 Python…

    2025年12月14日
    000
  • 在 Amazon Linux 2023 上安装安全加固的 pip

    本文档旨在指导用户在 Amazon Linux 2023 上安装与系统自带 Python 版本相对应的、经过安全加固的 pip 包。我们将探讨官方推荐的安装方式,确保获得与系统环境兼容且安全可靠的 pip 版本,以便进行后续的 Python 包管理。 在 Amazon Linux 2023 上,Py…

    2025年12月14日
    000
  • 在Amazon Linux 2023上安装安全加固的pip

    在Amazon Linux 2023上安装Python包管理器pip,并确保其安全性,是一个值得关注的问题。Amazon Linux 2023预装了Python,但默认情况下不包含pip。为了满足用户对安全和稳定性的需求,我们需要选择一种可靠的方式来安装pip。 正如前文所述,在Amazon Lin…

    2025年12月14日
    000
  • 使用F-string和集合时结果顺序错乱的原因分析及解决方案

    本文旨在解释在使用Python的f-string和集合(set)时,为何集合中的元素顺序与预期不符。文章将深入探讨集合的无序性,并对比列表(list)的有序性,帮助读者理解不同数据结构在f-string中的表现,从而避免因数据结构特性导致的误解。 在Python中使用f-string进行格式化输出时…

    2025年12月14日
    000
  • 使用 f-strings 格式化集合时,结果顺序为何与预期不符?

    本文旨在解释在使用 f-strings 格式化 Python 集合时,为何集合元素的顺序可能与预期不符。通过对比集合和列表的不同特性,阐明了集合的无序性导致输出结果顺序不确定的原因,并强调这与 f-strings 本身无关。理解集合的本质是解决此类问题的关键。 在 python 中,使用 f-str…

    2025年12月14日
    000
  • 使用f-string格式化集合时结果顺序不一致的原因

    本文旨在解释Python中使用f-string格式化集合(set)时,输出结果顺序不确定的原因。通过对比集合和列表的特性,阐明集合的无序性导致每次打印结果顺序可能不同的现象,并强调这与f-string本身无关。 在Python中,使用f-string可以方便地将表达式的值嵌入到字符串中。然而,当与集…

    2025年12月14日
    000
  • Python f-string 中集合表达式的无序性

    本文旨在解释 Python 中使用 f-string 结合集合推导式时,结果顺序不确定的原因。通过对比集合和列表推导式的差异,阐明集合的无序性导致输出结果顺序不稳定的现象,并强调这与 f-string 本身无关。 在 python 中,f-string 是一种强大的字符串格式化工具,它允许你在字符串…

    2025年12月14日
    000
  • 如何使用Python处理卫星图像?rasterio库教程

    使用rasterio处理卫星图像的基础方法包括:1.安装库并读取geotiff文件获取元数据和波段数据;2.查看图像波段结构并提取特定波段;3.结合matplotlib显示图像并调整对比度;4.保存处理后的图像并保留空间参考信息。首先,通过pip安装rasterio,并用open()函数读取文件,获…

    2025年12月14日 好文分享
    000
  • 如何使用Python生成报告?Jinja2模板应用指南

    使用python的jinja2模板引擎生成报告的关键步骤如下:1. 安装jinja2并确认环境正常,执行pip install jinja2后导入测试;2. 编写清晰结构的模板文件,如html或文本格式,合理使用变量和控制结构;3. 渲染报告时加载模板并传入匹配的数据,最终输出结果文件;4. 可结合…

    2025年12月14日 好文分享
    000
  • 如何用Python制作词云图?wordcloud配置指南

    制作词云图用python的wordcloud库即可,关键在于掌握参数设置和中文处理。步骤包括:1.安装库;2.加载文本并生成词云对象;3.显示或保存图片。中文支持需指定字体路径,并搭配jieba分词。自定义形状需导入遮罩图片,颜色可用colormap调整。其他技巧包括过滤停用词、限制最大词数、控制字…

    2025年12月14日 好文分享
    000
  • 如何使用Python连接SQLite?数据库操作完整流程

    使用python连接sqlite数据库并执行基础操作的解决方案如下:1.通过sqlite3.connect()建立连接;2.创建游标对象执行sql命令;3.使用create table if not exists创建表;4.通过executemany插入数据;5.利用execute和fetchall…

    2025年12月14日 好文分享
    000
  • 如何使用Python实现数据聚类?KMeans算法

    kmeans聚类的核心步骤包括数据预处理、模型训练与结果评估。1. 数据预处理:使用standardscaler对数据进行标准化,消除不同特征量纲的影响;2. 模型训练:通过kmeans类设置n_clusters参数指定簇数,调用fit方法训练模型;3. 获取结果:使用labels_属性获取每个数据…

    2025年12月14日 好文分享
    000

发表回复

登录后才能评论
关注微信