您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > Python

Python 数据处理,Pandas 使用方式的变局

时间:2023-12-12 13:14:25  来源:微信公众号  作者:数据大宇宙

前段时间在公司技术分享会上,同事介绍了目前市面上关于自动生成 pandas 代码的工具库。我们也尝试把这些工具库引入到工作流程中。经过一段时间的实践,最终还是觉得不适合,不再使用这些工具库。

今天就来给大家说一下其中的缘由,以及有什么其他可能的解决方案。

Python 数据处理,Pandas 使用方式的变局

操作生成代码

pandas 可以说是办公自动化的神器,毕竟大部分的任务都需要处理结构化数据。目前Python/ target=_blank class=infotextkey>Python生态中,已经有好几款能通过操作界面,自动生成 pandas 代码的工具库。

比如 Mito :

Python 数据处理,Pandas 使用方式的变局

比如 pandas gui:

Python 数据处理,Pandas 使用方式的变局

比如 dtale :

Python 数据处理,Pandas 使用方式的变局

他们可以通过你的手工操作,把操作过程中的代码生成出来。

听起来很不错吧。以后就不用自己写 pandas 就能轻松得到自动化处理脚本。事实却并非如此。

其实,自动生成代码这件事情,实现并不难。我并不是在说大话,因为以前我也制作过这种工具。但是最终因为发现了工具的瓶颈,而没有更新下去。当初我发现的那些工具瓶颈,恰恰是我们公司放弃这些工具库的主要原因。

工程化更重要

当初我之所以制作自动化生成pandas工具,主要是因为我会经常到 kaggle 上找一些数据做数据探索。

数据探索是一件非常"反代码"的事情,这是因为在你拿到数据之后,此时你并不知道下一步该怎么处理它。所以通常情况下,我会选择使用 Excel 的透视表完成这项任务。但是往往需要把最终的探索过程自动化。这就迫使我使用pandas做数据探索。

我会经常写出类似下面的代码结构:

Python 数据处理,Pandas 使用方式的变局

其实那时候我已经积累了不少常用的pandas自定义功能模块。但是,这种模式不方便分享。毕竟数据处理的常用功能其实非常多,套路和技巧如果都制作成模块,在公司团队协作上,学习成本很高。

那么,有没有其他的工具可以解决?期间我尝试过一些 BI 工具的使用。比如 power bi 的数据处理工具 power query。它可以解决一部分的问题,但远远没达到 pandas 的灵活。另一个让我印象深刻的工具就要数 tabluea 的数据工具 —— prep

本质上它与 power query 大同小异,不过它可以让流程可视化。下面是 prep 的工作界面:

Python 数据处理,Pandas 使用方式的变局

每次操作都能生成在流程图上体现,并且每一个节点都可以查看它的输入数据和输出结果。

Python 数据处理,Pandas 使用方式的变局

那时候我一下子明白了,为什么不管怎么规范和模块化pandas代码,总是感觉很难管理。

我们需要的并不是自动生成pandas代码,而是生成能体现流程的代码信息。

其实这也是我学习pandas的方法论,集中精力学习少数核心的方法,更重要的是学会数据流的思维。比如在我编写的pandas专栏中,就有一个案例讲解如何编排你的pandas代码:

Python 数据处理,Pandas 使用方式的变局

 

说回现有的一些自动生成代码的工具库,它们无一例外只是生成一大串密密麻麻的代码。你无法从中得知操作意图。过几天再看这些代码,你都无从下手。

有人会说,你可以自己定义函数,封装工具生成出来的代码。其实我们公司一开始也是这么干,但实际情况是,我们经常因为需求变化,而去改动里面的逻辑。此时因为工具无法再次重现你的操作步骤。你只能默默手工把代码实现一遍。

总的来说,这些工具的缺点是:

  • 没有可视化操作流程节点
  • 生成的代码没有函数化
  • 无法自定义功能

由此可以得知它的应用场景是一些非常简单或无须长期维护代码的任务。

既然上面说的 tableau prep 这么好,为什么不直接用它?因为它是收费的。并且它也无法做到自定义功能。

难道就不能破局吗?其实我从未放弃。

一切皆有可能

现在我们来推敲一下,目前有没有足够的工具实现"假想"。

要做可视化操作工具,首当其冲就是要制作操作界面。目前 python 已经有了许多 web ui 框架,其中本人觉得最灵活最有潜力的就是 nicegui 。我也已经推出了一系列相关的实战示例视频,其实我之所以学习 nicegui,正是希望为 pandas 以及 pybi-next 打造各种辅助工具。

用 nicegui 做一个大概的功能界面非常容易:

Python 数据处理,Pandas 使用方式的变局

该怎么样设计每一个功能的结构?比如,要实现上图功能区中的筛选功能,我们可以把每个功能视为一个函数:

Python 数据处理,Pandas 使用方式的变局

想办法让函数的各个参数映射成一个界面组件:

Python 数据处理,Pandas 使用方式的变局

这是一个在 juperter notebook 的一个界面组件库给到我的启发。利用装饰器,函数定义的参数类型等信息,可以自动根据函数创建对应的可视化界面。

在导出代码的时候,我们无须把函数里面的散乱的代码输出,而是直接输出函数定义,以及函数的调用即可。

也就是说,假如用户在界面上操作了两次筛选功能,生成的代码是这样子:

Python 数据处理,Pandas 使用方式的变局

这就解决了输出代码过于散乱的问题。

不仅如此,使用者同样可以通过这种方式轻易制作自定义的功能。

那么,怎么可以制作出类似 tableau prep 的操作流程界面?由于 nicegui 本身的灵活性,我们可以充分利用前端强大的资源,在我之前的文章中,就介绍过关于这方面的实现。

Python 数据处理,Pandas 使用方式的变局

Python 数据处理,Pandas 使用方式的变局

只要整体机制能跑通,剩下的只是实现细节而已。接下来,我也会把制作过程涉及到的一些有用的python知识分享出来。



Tags:Python   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
Python 可视化:Plotly 库使用基础
当使用 Plotly 进行数据可视化时,我们可以通过以下示例展示多种绘图方法,每个示例都会有详细的注释和说明。1.创建折线图import plotly.graph_objects as go# 示例1: 创建简单...【详细内容】
2024-04-01  Search: Python  点击:(8)  评论:(0)  加入收藏
Python 办公神器:教你使用 Python 批量制作 PPT
介绍本文将介绍如何使用openpyxl和pptx库来批量制作PPT奖状。本文假设你已经安装了python和这两个库。本文的场景是:一名基层人员,要给一次比赛活动获奖的500名选手制作奖状,并...【详细内容】
2024-03-26  Search: Python  点击:(15)  评论:(0)  加入收藏
Python实现工厂模式、抽象工厂,单例模式
工厂模式是一种常见的设计模式,它可以帮助我们创建对象的过程更加灵活和可扩展。在Python中,我们可以使用函数和类来实现工厂模式。一、Python中实现工厂模式工厂模式是一种常...【详细内容】
2024-03-07  Search: Python  点击:(31)  评论:(0)  加入收藏
不可不学的Python技巧:字典推导式使用全攻略
Python的字典推导式是一种优雅而强大的工具,用于创建字典(dict)。这种方法不仅代码更加简洁,而且执行效率高。无论你是Python新手还是有经验的开发者,掌握字典推导式都将是你技能...【详细内容】
2024-02-22  Search: Python  点击:(32)  评论:(0)  加入收藏
如何进行Python代码的代码重构和优化?
Python是一种高级编程语言,它具有简洁、易于理解和易于维护的特点。然而,代码重构和优化对于保持代码质量和性能至关重要。什么是代码重构?代码重构是指在不改变代码外部行为的...【详细内容】
2024-02-22  Search: Python  点击:(32)  评论:(0)  加入收藏
Python开发者必备的八个PyCharm插件
在编写代码的过程中,括号几乎无处不在,以至于有时我们会拼命辨别哪个闭合括号与哪个开头的括号相匹配。这款插件能帮助解决这个众所周知的问题。前言在PyCharm中浏览插件列表...【详细内容】
2024-01-26  Search: Python  点击:(84)  评论:(0)  加入收藏
Python的Graphlib库,再也不用手敲图结构了
Python中的graphlib库是一个功能强大且易于使用的工具。graphlib提供了许多功能,可以帮助您创建、操作和分析图形对象。本文将介绍graphlib库的主要用法,并提供一些示例代码和...【详细内容】
2024-01-26  Search: Python  点击:(85)  评论:(0)  加入收藏
大语言模型插件功能在携程的Python实践
作者简介成学,携程高级安全研发工程师,关注Python/Golang后端开发、大语言模型等领域。一、背景2023年初,科技圈最火爆的话题莫过于大语言模型了,它是一种全新的聊天机器人模型,...【详细内容】
2024-01-26  Search: Python  点击:(73)  评论:(0)  加入收藏
如何使用Python、Apache Kafka和云平台构建健壮的实时数据管道
译者 | 李睿审校 | 重楼在当今竞争激烈的市场环境中,为了生存和发展,企业必须能够实时收集、处理和响应数据。无论是检测欺诈、个性化用户体验还是监控系统,现在都需要接近即时...【详细内容】
2024-01-26  Search: Python  点击:(46)  评论:(0)  加入收藏
Python分布式爬虫打造搜索引擎
简单分布式爬虫结构主从模式是指由一台主机作为控制节点负责所有运行网络爬虫的主机进行管理,爬虫只需要从控制节点那里接收任务,并把新生成任务提交给控制节点就可以了,在这个...【详细内容】
2024-01-25  Search: Python  点击:(58)  评论:(0)  加入收藏
▌简易百科推荐
Python 可视化:Plotly 库使用基础
当使用 Plotly 进行数据可视化时,我们可以通过以下示例展示多种绘图方法,每个示例都会有详细的注释和说明。1.创建折线图import plotly.graph_objects as go# 示例1: 创建简单...【详细内容】
2024-04-01  Python技术    Tags:Python   点击:(8)  评论:(0)  加入收藏
Python 办公神器:教你使用 Python 批量制作 PPT
介绍本文将介绍如何使用openpyxl和pptx库来批量制作PPT奖状。本文假设你已经安装了python和这两个库。本文的场景是:一名基层人员,要给一次比赛活动获奖的500名选手制作奖状,并...【详细内容】
2024-03-26  Python技术  微信公众号  Tags:Python   点击:(15)  评论:(0)  加入收藏
Python实现工厂模式、抽象工厂,单例模式
工厂模式是一种常见的设计模式,它可以帮助我们创建对象的过程更加灵活和可扩展。在Python中,我们可以使用函数和类来实现工厂模式。一、Python中实现工厂模式工厂模式是一种常...【详细内容】
2024-03-07  Python都知道  微信公众号  Tags:Python   点击:(31)  评论:(0)  加入收藏
不可不学的Python技巧:字典推导式使用全攻略
Python的字典推导式是一种优雅而强大的工具,用于创建字典(dict)。这种方法不仅代码更加简洁,而且执行效率高。无论你是Python新手还是有经验的开发者,掌握字典推导式都将是你技能...【详细内容】
2024-02-22  子午Python  微信公众号  Tags:Python技巧   点击:(32)  评论:(0)  加入收藏
如何进行Python代码的代码重构和优化?
Python是一种高级编程语言,它具有简洁、易于理解和易于维护的特点。然而,代码重构和优化对于保持代码质量和性能至关重要。什么是代码重构?代码重构是指在不改变代码外部行为的...【详细内容】
2024-02-22  编程技术汇    Tags:Python代码   点击:(32)  评论:(0)  加入收藏
Python开发者必备的八个PyCharm插件
在编写代码的过程中,括号几乎无处不在,以至于有时我们会拼命辨别哪个闭合括号与哪个开头的括号相匹配。这款插件能帮助解决这个众所周知的问题。前言在PyCharm中浏览插件列表...【详细内容】
2024-01-26  Python学研大本营  微信公众号  Tags:PyCharm插件   点击:(84)  评论:(0)  加入收藏
Python的Graphlib库,再也不用手敲图结构了
Python中的graphlib库是一个功能强大且易于使用的工具。graphlib提供了许多功能,可以帮助您创建、操作和分析图形对象。本文将介绍graphlib库的主要用法,并提供一些示例代码和...【详细内容】
2024-01-26  科学随想录  微信公众号  Tags:Graphlib库   点击:(85)  评论:(0)  加入收藏
Python分布式爬虫打造搜索引擎
简单分布式爬虫结构主从模式是指由一台主机作为控制节点负责所有运行网络爬虫的主机进行管理,爬虫只需要从控制节点那里接收任务,并把新生成任务提交给控制节点就可以了,在这个...【详细内容】
2024-01-25  大雷家吃饭    Tags:Python   点击:(58)  评论:(0)  加入收藏
使用Python进行数据分析,需要哪些步骤?
Python是一门动态的、面向对象的脚本语言,同时也是一门简约,通俗易懂的编程语言。Python入门简单,代码可读性强,一段好的Python代码,阅读起来像是在读一篇外语文章。Python这种特...【详细内容】
2024-01-15  程序员不二    Tags:Python   点击:(161)  评论:(0)  加入收藏
Python语言的特点及应用场景, 同其它语言对比优势
Python语言作为一种高级编程语言,具有许多独特的特点和优势,这使得它在众多编程语言中脱颖而出。在本文中,我们将探讨Python语言的特点、应用场景以及与其他语言的对比优势。一...【详细内容】
2024-01-09    今日头条  Tags:Python语言   点击:(251)  评论:(0)  加入收藏
站内最新
站内热门
站内头条