利用Pandas按字典映射聚合DataFrame列

利用pandas按字典映射聚合dataframe列

本文将详细介绍如何使用Pandas高效地根据一个字典来聚合DataFrame的列。该字典定义了新的列名及其对应的原始DataFrame列列表。我们将探讨两种Pythonic且高效的方法:一种利用`groupby(axis=1)`进行列分组求和,另一种则通过转置DataFrame来适应新版Pandas中`groupby`行为的变化,确保解决方案的兼容性和性能。

在数据分析和处理中,我们经常需要根据特定的规则对DataFrame的列进行组合或聚合。一个常见的场景是,我们有一个DataFrame和一份映射字典,字典的键是新的列名,值是需要聚合的原始DataFrame列名的列表。例如,如果字典中’x’: [‘A’, ‘D’],则新的DataFrame中的’x’列应该是原始DataFrame中’A’和’D’列的行级和。本教程将展示如何以Pandas的惯用方式(Pythonic)实现这一目标,避免使用低效的循环。

示例数据准备

首先,我们创建用于演示的DataFrame和映射字典:

import pandas as pddf = pd.DataFrame([[4, 8, 52, 7, 54],                   [0, 20, 2, 21, 35],                   [2, 33, 12, 1, 87]],                  columns=['A', 'B', 'C', 'D', 'E'])dic = {'x': ['A', 'D'], 'y': ['E'], 'z': ['B', 'C']}print("原始DataFrame:")print(df)print("n映射字典:")print(dic)

原始DataFrame df 如下:

   A   B   C   D   E0  4   8  52   7  541  0  20   2  21  352  2  33  12   1  87

我们的目标是生成一个新DataFrame,其中包含 x, y, z 三列,分别对应 (A+D), (E), (B+C) 的行级和。

方法一:利用 rename 和 groupby(axis=1)

这种方法的核心思想是:首先创建一个“逆向”字典,将原始列名映射到它们应该归属的新列名。然后,利用 df.rename() 临时性地将DataFrame的列名修改为这些新的聚合组名。最后,通过 groupby(level=0, axis=1).sum() 对具有相同新列名的列进行分组求和。

创建逆向字典 d2:这个字典将原始列名作为键,新的聚合列名作为值。例如,’A’ 应该映射到 ‘x’,’D’ 也应该映射到 ‘x’。

d2 = {v: k for k, l in dic.items() for v in l}print("n逆向字典 d2:")print(d2)

输出 d2:

{'A': 'x', 'D': 'x', 'E': 'y', 'B': 'z', 'C': 'z'}

重命名列并分组求和:使用 df.rename(columns=d2) 将 df 的列名根据 d2 进行重命名。例如,列 A 和 D 都会被重命名为 x。然后,groupby(level=0, axis=1).sum() 会沿着列方向(axis=1)对具有相同名称的列进行分组,并计算它们的和。level=0 在这里是默认值,表示按列名本身进行分组。

out_method1 = df.rename(columns=d2).groupby(level=0, axis=1).sum()print("n方法一结果:")print(out_method1)

输出结果:

    x   y   z0  11  54  601  21  35  222   3  87  45

这里的 x 列是 A+D 的和 (4+7=11, 0+21=21, 2+1=3),y 列是 E 的值,z 列是 B+C 的和 (8+52=60, 20+2=22, 33+12=45)。

方法二:利用转置 (.T) 和 groupby (适用于新版Pandas)

在某些较新版本的Pandas中,直接在 groupby 中使用 axis=1 可能会被弃用。为了保持兼容性并提供另一种高效的解决方案,我们可以利用DataFrame的转置操作。

创建逆向字典 d2:这一步与方法一相同,因为我们需要相同的映射关系。

d2 = {v: k for k, l in dic.items() for v in l}

转置、重命名、分组求和并再次转置:

df.T: 将DataFrame转置,原始列变为索引,原始索引变为列。.rename(d2): 此时 d2 会作用于转置后DataFrame的索引(即原始的列名)。这样,原始列 A, D 对应的索引都会被重命名为 x。.groupby(level=0).sum(): 对转置后DataFrame的索引(现在是新的聚合组名)进行分组求和。.T: 再次转置,将结果恢复到原始的行/列布局。

out_method2 = df.T.rename(d2).groupby(level=0).sum().Tprint("n方法二结果:")print(out_method2)

输出结果与方法一相同:

    x   y   z0  11  54  601  21  35  222   3  87  45

注意事项与总结

Pythonic与效率: 这两种方法都避免了显式循环,利用了Pandas底层的优化C/Cython实现,因此在大规模数据集上表现出更高的效率。灵活性: 这种模式非常灵活,不仅限于求和,还可以用于其他聚合操作(如 mean, max, min 等),只需将 .sum() 替换为相应的聚合函数即可。版本兼容性: 方法一在多数Pandas版本中都有效,但方法二提供了对未来版本更强的兼容性,以防 groupby(axis=1) 被完全弃用。建议在生产环境中使用方法二。字典理解: d2 = {v: k for k, l in dic.items() for v in l} 是一个高效且简洁的字典理解,用于反转和扁平化字典结构。

通过上述方法,我们可以优雅且高效地根据自定义的字典映射关系来聚合DataFrame的列,这在数据清洗、特征工程等场景中非常实用。掌握这些Pandas技巧将显著提升数据处理的效率和代码的可读性。

以上就是利用Pandas按字典映射聚合DataFrame列的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
CPython自定义类型初始化器中安全引用计数的实践与陷阱解析
上一篇 2025年12月14日 19:45:37
解决NetBeans 20中Python插件安装失败的问题
下一篇 2025年12月14日 19:45:46

相关推荐

  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    000
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • Python递归函数追踪与性能考量:以序列打印为例

    本文深入探讨了Python中一种递归打印序列元素的方法,并着重演示了如何通过引入缩进参数来有效追踪递归函数的执行流程和参数变化。通过实际代码示例,文章揭示了递归调用可能带来的潜在性能开销,特别是对调用栈空间的需求,以及Python默认递归深度限制可能导致的错误,为读者提供了理解和优化递归算法的实用见…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • Python 函数参数类型:如何使用可变参数和动态参数?

    python 中的参数类型:关键词参数、可变参数和动态参数 在 python 中,函数的参数可以分为以下几种类型: 关键词参数(kw)**:这些参数具有名称,并且在调用函数时明确指定。可变参数(*args):这些参数没有名称,允许函数接受任意数量的位置参数。它们将被收集到一个元组中。动态参数(kwa…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • python中numpy的用法

    NumPy是Python中用于科学计算的强大库,它提供了以下功能:多维数组处理矩阵运算快速傅里叶变换(FFT)线性代数随机数生成 NumPy在Python中的强大功能 NumPy是Python中用于科学计算的一个强大且灵活的库。它提供了用于处理多维数组和矩阵的一组高效工具,是数据分析和机器学习项目的…

    2026年5月10日
    100
  • python如何捕获所有类型的异常_python try except捕获所有异常的方法

    答案:捕获所有异常推荐使用except Exception as e,可捕获常规错误并记录日志,避免影响程序正常退出;需拦截系统信号时才用except BaseException as e。 在Python中,要捕获所有类型的异常,最常见且推荐的方法是使用 except Exception as e…

    2026年5月10日
    000
  • python中f怎么用

    f-字符串是 Python 3.6 中引入的格式化字符串语法糖,提供了简洁且安全的方式来插入表达式和变量。f-字符串以字符串前缀 f 为标志,使用大括号包含表达式或变量。f-字符串支持条件表达式和格式规范符,提供了更大的灵活性、安全性、可读性和易维护性。 在 Python 中使用 f-字符串 f-字…

    2026年5月10日
    100
  • 怎么在手机上把XML文件转换为PDF?

    不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。 怎么在手机上把XML文件转换为PDF? 这问题问得好,比直接问“怎么转换”有深度多了!因为它触及了移动端环境的…

    2026年5月10日
    000
  • ReCAPTCHA V3低分处理策略:结合V3与V2实现智能风险控制与用户验证

    本文旨在解决ReCAPTCHA V3在低分情况下无法直接触发验证码挑战的问题。我们将探讨如何通过巧妙地结合ReCAPTCHA V3的无感评分机制与ReCAPTCHA V2的交互式挑战,实现一套既能有效阻挡机器人流量,又能最大限度减少对合法用户干扰的智能验证系统。文章将详细阐述其实现原理、前端与后端集…

    2026年5月10日
    100
  • Python正则表达式:处理数字不同情况的替换

    本文旨在帮助读者理解和解决在使用Python正则表达式进行数字替换时遇到的问题。通过具体示例,详细解释了如何正确匹配和替换不同格式的数字,避免常见的匹配陷阱,并提供可直接使用的代码示例。掌握这些技巧,能有效提高处理文本数据的效率和准确性。 在使用Python的re模块进行字符串替换时,正则表达式的编…

    2026年5月10日
    000
  • python的tuple什么意思

    元组是Python中一种有序、不可变的序列数据结构。用于存储相关数据,例如坐标、个人信息或枚举值。创建方式:圆括号(),元素以逗号,分隔。访问元素:索引运算符;遍历元素:for循环。 什么是Python中的Tuple? Tuple,中文称为元组,是Python中一种有序、不可变的序列数据结构。 特点…

    2026年5月10日
    000
  • Python官网用户调查的参与方式_Python官网反馈提交详细教程

    答案是通过访问Python官网新闻页面、邮件邀请链接或GitHub仓库提交反馈。具体为:访问官网查找用户调查公告,或点击邮件中的专属链接参与,在GitHub的cpython仓库提交技术建议,并注意如实填写问卷与保护隐私。 如果您希望参与Python官网的用户调查并提交反馈,可以通过官方指定的渠道完成…

    2026年5月10日
    000
  • 我有时使用 awk 而不是 Python 的四个原因

    Python 是一门强大的编程语言,但在某些特定场景下,Awk 的优势更为显著,尤其体现在可移植性、生命周期、代码简洁性和与其他工具的互操作性方面。 Python 脚本通常具有良好的可移植性,但并非总能在所有环境中完美运行,例如流行的 Docker 基础镜像 (如 Debian 和 Alpine)。…

    2026年5月10日
    000
  • Python字符串格式化进阶:解包与f-string的巧妙应用

    本文深入探讨了Python中字符串格式化的多种方法,重点讲解了元组解包与f-string的结合使用。通过示例代码,详细比较了%操作符、str.format()方法以及f-string在元组解包场景下的应用,并提供了在f-string中使用斜杠分隔符的更简洁方案,旨在帮助读者掌握更高效、更易读的字符串…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信