作者:Cherish
来源:https://www.jianshu.com/p/91128d442198
本文为读者投稿

决定写这篇文章的初衷是来源于一位小伙伴的问题,关于"如何根据数据源用 Python 自动生成透视表",这个问题背后有个非常好的解决思路,让代码替我们做重复的工作,从而减轻工作量,减少出错。

Python 开发的小工具实际上是将 Python 程序打包成 exe,分享即可用,即便电脑没有安装 Python 环境,也可以使用,用代码提高工作效率,尽量少加班。

内容大纲

  • 明确需求:自动生成透视表【这部分可以换成你的重复性工作】

  • 安装三方依赖库:tkinter 和 pyinstaller

  • 代码实现:包括两部分 Python 生成透视表和桌面 GUI 联动设计

  • 打包 Python 程序 生成 exe 可执行文件

  • 解决 exe 文件可能过大问题:安装虚拟环境

一、需求背景

将工作中重复性的操作,利用供应商名称,月份,入库金额三个字段来生成想要的透视表格式。

二、安装三方依赖库

创建桌面窗口,这里使用 tkinter,它是 Python 自带的 GUI 库,安装后即可使用。

pip install tkinter

使用 pyinsatller 将程序打包成 exe,好处是不需要将代码部署到服务器,直接将打包好的 exe 发给对方,就能直接使用,对于这种小而轻的功能非常友好。

pip install pyinstaller

三、代码实现

Excel 文件生成透视表和筛选数据,文件名:excel_to_pivot.py

import pandas as pd
import numpy as npclass ExcelToPivot(object):def __init__(self, filename, file_path):self.file_name = filenameself.file_path = file_path"""excel自动转透视表功能返回透视结果"""def excel_Pivot(self):print(self.file_path)data = pd.read_excel(self.file_path)data_pivot_table = pd.pivot_table(data, index=['供应商名称', '月份'], values=["入库金额"], aggfunc=np.sum)return data_pivot_table"""按条件筛选,并保存"""def select_data(self, name, month):data_pivot_table = self.excel_Pivot()data_new = data_pivot_table.query('供应商名称 == ["{}"] & 月份 == {}'.format(name, month))data_new.to_excel('{}.xlsx'.format(str(self.file_name).split('.')[0]))return '筛选完成!'if __name__ == '__main__':filename = input("请输入文件名字:")path = 'C:/Users/cherich/Desktop/' + filenamepross = ExcelToPivot(filename, path)print(pross.select_data("C", 4))

设计桌面窗口功能,文件名:opration.py

from tkinter import Tk, Entry, Button, mainloop
import tkinter.filedialog
import excel_to_pivot
from tkinter import messagebox
from tkinter import ttkdef Upload():global filename, data_pivot_tabletry:filename = tkinter.filedialog.askopenfilename(title='选择文件')pross = excel_to_pivot.ExcelToPivot(str(filename).split('/')[-1], filename)data_pivot_table = pross.excel_Pivot()messagebox.showinfo('Info', '转换成功!')except Exception as e:print(e)messagebox.showinfo('Info', '转换失败!')def select(name, month):try:print('供应商名称 == ["{}"] & 月份 == {}'.format(name, month))data_new = data_pivot_table.query('供应商名称 == ["{}"] & 月份 == {}'.format(name, month))data_new.to_excel('{}.xlsx'.format(str(filename).split('.')[0]))messagebox.showinfo('Info', '筛选完成并生成文件!')root.destroy()except Exception as e:print(e)messagebox.showinfo('Info', '筛选失败!')root = Tk()
root.config(background="#6fb765")
root.title('自动转透视表小工具')
root.geometry('500x250')
e1 = Entry(root, width=30)
e1.grid(row=2, column=0)btn1 = Button(root, text=' 上传文件 ', command=Upload).grid(row=2, column=10, pady=5)box1 = ttk.Combobox(root)
# 使用 grid() 来控制控件的位置
box1.grid(row=5, sticky="NW")
# 设置下拉菜单中的值
box1['value'] = ('A', 'B', 'C', 'D', '供应商')
# 通过 current() 设置下拉菜单选项的默认值
box1.current(4)box2 = ttk.Combobox(root)
box2.grid(row=5, column=1, sticky="NW")
box2['value'] = (1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, '月份')
box2.current(12)# 编写回调函数,绑定执行事件
def func(event):global b1, b2b1 = box1.get()b2 = box2.get()# 绑定下拉菜单事件
box1.bind("<<ComboboxSelected>>", func)
box2.bind("<<ComboboxSelected>>", func)
btn2 = Button(root, text=' 筛选数据 ', command=lambda: select(b1, b2)).grid(row=30, column=10, pady=5)
mainloop()

如果运行结果如上,说明代码没有问题了,可以进行下一步。

四、打包 Python 程序生成 exe

打开 DOS 窗口并切换到 两个 py 文件所在的目录,注意路径中不要有中文。

pyinsatller -F -w opration.py

pyinstaller 指令的常见可选参数:

  • -i 给应用程序添加图标

  • -F 指定打包后只生成一个exe格式的文件

  • -D –onedir 创建一个目录,包含exe文件,但会依赖很多文件(默认选项)

  • -c –console, –nowindowed 使用控制台,无界面(默认)

  • -w –windowed, –noconsole 使用窗口,无控制台

  • -p 添加搜索路径

在当前的目录下,将会生成两个文件夹:build 和 dist。dist 里面就是所有可执行 exe 文件,发送快捷方式到桌面,点击 opration.exe 就能运行了,可以发它的快捷方式发送到桌面,双击就可以。

五、解决 exe 文件可能过大问题

有的伙伴 Python 环境刚安装没多久,可能不存在这个文件过大的问题。像我的电脑里安装了 Python 很多的依赖包和 anaconda 等等,打包出来的文件居然 660M,打包时间长,执行时还卡,后来经过整改缩小到 31M,打包快,秒级执行。解决方案是在 Windows 系统下安装一个 Python 的虚拟环境,前提是已经在电脑上安装过 Python 才可以进行如下操作。

找到 Python 所在路径,如果忘记了,可以在电脑左下角搜索【编辑系统环境变量】——【用户变量】——【PATH】中找到

配置虚拟环境

虚拟环境可以理解为是 Python 解释器的一个副本,在这个环境你可以安装私有包,而且不会影响系统中安装的全局 Python 解释器。虚拟环境非常有用,可以在系统的 Python 解释器中避免包的混乱和版本的冲突。

重要是不同虚拟环境可以搭建不同的 Python 版本,创建时候选择,我们这里需要一个相对 "干净" 的 Python 环境,没有安装过多依赖包,避免 exe 打包文件过大,所以用到虚拟环境。

安装虚拟环境依赖包

pip install virtualenv
pip install virtualenvwrapper-win

创建虚拟环境命令

mkvirtualenv -p="C:\Users\cherich\AppData\Local\Programs\Python\Python38\python.exe" py38

进入虚拟环境,可以看到只有几个默认的 Python 库

这时可以测试一下代码,是否缺少相关依赖,比如我这个缺少 Pandas,openpyxl,依次按照 pip install 包名安装即可,非常重要的点:pyinstaller 必须重新安装,文件才会缩小。

上述操作完成后,打包就可以了,最后退出虚拟环境即可。

退出虚拟环境

deactivate

整个自动化思路的实现就完成了,大家可以将整个流程套用到你现有的重复性工作中,在过程中有两个需要注意的点,如下:

尽量不要用中文路径,要不会报些莫名其妙的错误。

导包是尽量避免使用 import * 导入不必要的包,节省打包和执行时间。

让代码自动工作,省下来的时间,喝喝茶,陪陪你的女神!今天的文章写到这里,如果你觉得有用,欢迎点赞呐 !

END -

对比Excel系列图书累积销量达15w册,让你轻松掌握数据分析技能,可以在全网搜索书名进行了解:

Python 开发桌面小工具,让代码替我们干重复的工作!相关推荐

  1. 太强了,Python 开发桌面小工具,让代码替我们干重复的工作~

    作者 | Cherish 来源 | 杰哥的IT之旅 决定写这篇文章的初衷是来源于一位小伙伴的问题,关于"如何根据数据源用 Python 自动生成透视表",这个问题背后有个非常好的解 ...

  2. 太强了!Python 开发桌面小工具,让代码替我们干重复的工作!

    作者:Cherish 来源:https://www.jianshu.com/p/91128d442198 决定写这篇文章的初衷是来源于一位小伙伴的问题,关于"如何根据数据源用 Python ...

  3. 太强了~Python 开发桌面小工具,让代码替我们干重复的工作

    决定写这篇文章的初衷是来源于一位小伙伴的问题,关于"如何根据数据源用 Python 自动生成透视表",这个问题背后有个非常好的解决思路,让代码替我们做重复的工作,从而减轻工作量,减 ...

  4. android AppWidgetProvider开发桌面小工具

    什么是桌面小工具  就是你写好代码后 双指缩放桌面屏幕(三星手机出现小组件,华为出现窗口小工具)点击之后会出现你继承AppWidgetProvider所编写的界面 效果: 代码: /** * Impl ...

  5. 使用python快速开发桌面小工具

    参考链接 Welcome to Python.org Extending and Embedding the Python Interpreter - Python 3.7.3 documentati ...

  6. python开发网络小工具_python 网络工具

    书籍:掌握Python的网络和安全 Mastering Python for Networking and Security - 2018.pdf 简介 掌握Python的网络和安全 掌握Python ...

  7. python开发网络小工具_Python集成网络诊断小工具(含有ping,tracert,tcping等小工具)...

    之前在一家IDC公司实习,负责服务器售后方面的,经常要使用ping,tracert,tcping等命令做些初步的诊断,判断服务器问题出在哪方面.于是就想集成这些常用的命令或工具到一个GUI界面中,实现 ...

  8. python开发网络小工具_Python 实现简单网络应用程序开发

    最后一次更新于 2019/07/10 ICMP Ping 目的 此任务是重新创建第3讲(延迟,丢失和吞吐量)中讨论的ping客户端. Ping 是一个用于在计算机网络中测量延迟和丢失的工具. 在实际应 ...

  9. 使用Python开发测试小工具-录制回放工具的实现

    Pyqt5 信号槽机制可参考:https://blog.51cto.com/9291927/2422187 信号槽是Qt的核心机制,也是PyQt编程中对象进行通信的机制.在Qt中,QObject对象和 ...

最新文章

  1. Java终止当前线程的方法
  2. 机器狗背上枪成了无人杀手,6.5mm口径1200米射程,制造商已与美澳军队广泛合作...
  3. NYOJ 5767 装背包
  4. 测试core :: demangled_name
  5. JUnit测试方法订购
  6. 为什么在python中整数的值没有限制_python-为什么math.log接受大整数值?
  7. IDEA运行VUE npm install报错:chromedriver@2.27.2 install: node install.js
  8. python将学号与成绩匹配_用Python运维网络(1):基础知识
  9. docker 启动容器的时候没-p 后面怎么加-p_基于Docker搭建基础自动化部署
  10. vijos P1001 谁拿了最多奖学金
  11. dh算法 理论依据_DH算法为什么属于非对称加密算法?
  12. uboot源码修改之支持DM9000
  13. 一文带你了解Windows操作系统安全,保护自己的电脑不受侵害
  14. 国内比较好的云服务提供商有哪些?
  15. 网络共享计算机权限访问,局域网共享时提示:你没有权限访问,请与网络管理员联系...
  16. php图片上传保留第一帧,七牛云上传视频怎么截取第一帧为图片
  17. (2017中国数字化贡献人物专访)相宜本草:数字化生态转型实现IT部门角色跃迁...
  18. 公开在线讲座|Tamer Özsu教授:图处理-全景式视角和开放性问题
  19. 上市公司股利分红数据(1991-2020)
  20. 数据结构 之 无向连通图

热门文章

  1. pythondockerapi_docker-py 用Python调用Docker接口的方法
  2. 同步和原子性---多线程学习笔记(四)
  3. JavaScript基础总结(五)——Math对象
  4. 资深专家深度剖析Kubernetes API Server第2章(共3章)
  5. 理解React-组件生命周期
  6. [Debugging]分析博客园提交评论的校验规则
  7. Python中的条件选择和循环语句
  8. flume+elasticsearch日志收集分析
  9. Contracts for Java
  10. Rabbitmq集群高可用部署详细