痞子衡
认证:普通会员
所在专题目录 查看专题
200行Python代码实现串口调试助手(1) - 环境搭建
200行Python代码实现串口调试助手(2) - 界面构建
200行Python代码实现串口调试助手(3) - 功能实现
200行Python代码实现串口调试助手(4) - 联合调试
200行Python代码实现串口调试助手(5) - 软件优化
200行Python代码实现串口调试助手(6) - 打包发布
作者动态 更多
复合数据类型在C/C++下混合编译注意事项
2小时前
加了ECC保护之后的运存性能有何影响?
1星期前
第一本Git命令教程(2) - 连接
3星期前
MCU里硬件CRC对数据长度对齐有要求?
11-26 11:14
为什么DCP硬件引擎做Hash校验偶尔会失败?
11-21 09:26

200行Python代码实现串口调试助手(6) - 打包发布

大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是串口调试工具pzh-py-com诞生之打包发布

经过上一篇软件优化之后,pzh-py-com已经初长成,该到了出去历练的时候了,只有经历广大群众考验过的软件才是合格的软件。痞子衡在开发pzh-py-com时本地安装了很多软件:Python、pySerial、wxPython等,这些软件是pzh-py-com运行的基础,但如果将来别人想用pzh-py-com,是不是也需要安装这些软件呢?答案当然不是,如果是的话,pzh-py-com基本就没人愿意使用了。为了让别人能够不需要特殊环境便能运行pzh-py-com,我们需要将pzh-py-com打包成独立可执行文件,此时我们需要借助专门的Python打包工具,本篇是这个系列的最后一篇,痞子衡为大家讲如何使用打包工具打包pzh-py-com去发布。

一、PyInstaller简介

Python打包工具有很多,如py2exe、cx_Freeze、PyInstaller,其中痞子衡首推PyInstaller。PyInstaller诞生于2005年,经过这么多年的发展,其版本已经更新到v3.x,其主页如下:

PyInstaller官方主页: http://www.pyinstaller.org/PyInstaller的github主页: https://github.com/pyinstaller/pyinstaller

在使用PyInstaller进行打包工作之前,首先需要确定你的Python应用程序所调用的所有第三方库是不是在PyInstaller支持列表里,这个主页显示了PyInstaller支持的所有第三方库:https://github.com/pyinstaller/pyinstaller/wiki/Supported-Packages,基本上常用的第三方库都在列表里,比如Django、numpy、PyGame、PyOpenGL、PyQt、PyWin32等。  PyInstaller的使用非常简单,可先阅读一遍官方文档。对于pzh-py-com的打包,我们只需要掌握-F、-w、-i三个命令选项以及.spec文件使用就可以了。

PyInstaller官方文档主页: https://readthedocs.org/projects/pyinstaller/PyInstaller 3.3.1命令上手: https://pyinstaller.readthedocs.io/en/v3.3.1/usage.html#optionsPyInstaller 3.3.1 spec文件: https://pyinstaller.readthedocs.io/en/v3.3.1/spec-files.html#using-spec-files

二、将JaysPyCOM打包

安装好PyInstaller工具便可以开始打包pzh-py-com软件了,让我们开始吧,开始之前先介绍下pzh-py-com文件夹目录结构,结构目录是很简单的,只有三个.py源文件和三张图片,这构成了pzh-py-com软件的全部源文件。

\pzh-py-com
           \.idea                          --放置PyCharm工程文件
           \bin                            --放置工程发布的exe文件
           \gui                            --放置工程GUI设计文件
                  \pzh-py-com.fbp            --wxFormBuilder工程文件
           \img                            --放置工程引用图片文件
                  \led_black.png?x-oss-process=image/watermark,g_center,image_YXJ0aWNsZS9wdWJsaWMvd2F0ZXJtYXJrLnBuZz94LW9zcy1wcm9jZXNzPWltYWdlL3Jlc2l6ZSxQXzQwCg==,t_20
                  \led_green.png?x-oss-process=image/watermark,g_center,image_YXJ0aWNsZS9wdWJsaWMvd2F0ZXJtYXJrLnBuZz94LW9zcy1wcm9jZXNzPWltYWdlL3Jlc2l6ZSxQXzQwCg==,t_20
                  \logo_merge.jpg?x-oss-process=image/watermark,g_center,image_YXJ0aWNsZS9wdWJsaWMvd2F0ZXJtYXJrLnBuZz94LW9zcy1wcm9jZXNzPWltYWdlL3Jlc2l6ZSxQXzQwCg==,t_20
           \src                            --放置工程源代码文件
                  \formatter.py    --工程linker文件
                  \main.py         --板级相关的源文件(比如pinout,clock等)
                  \win.py          --wxPython窗口源文件(wxFormBuilder生成)

2.1 打包准备

由于pzh-py-com应用程序总共只有6个源文件,并且都已经准备就绪,pzh-py-com依赖的pySerial、wxPython库也都在PyInstaller支持的列表里,所以唯一剩下的准备工作便是制作pzh-py-com的图标文件。  

要制作图标文件,首先你得有一张图片文件,痞子衡将pySerial的logo截取了部分用作pzh-py-com的图标,有了图片,可以使用这个网站 https://converticon.com/ 将其转换成图标文件(.ico),图标文件制作好之后将其放在 \pzh-py-com\img\目录下:

\pzh-py-com
           \img                            --放置工程引用图片文件
                  \pzh-py-com.png?x-oss-process=image/watermark,g_center,image_YXJ0aWNsZS9wdWJsaWMvd2F0ZXJtYXJrLnBuZz94LW9zcy1wcm9jZXNzPWltYWdlL3Jlc2l6ZSxQXzQwCg==,t_20
                  \pzh-py-com.ico

2.2 开始打包

准备工作就绪,可以开始打包了,在使用PyInstaller打包前必须明白一点的是,PyInstaller仅能将.py格式的源文件以及其所调用的相关Python第三方源文件库打包进最终的.exe文件,如果你的应用程序会用到图片等多媒体文件,这些多媒体文件并不能被打包,后续exe在使用时,这些多媒体文件必须一同在场,并且还要保证与打包/开发时的相对路径是一致的。  

痞子衡使用的是如下命令格式打包pzh-py-com: pystaller -F -w [src1.py] [src2.py]... -i [pic.ico],解释一下这个命令组合,-F的意思是将应用程序打包成单个可执行文件(与其对立的命令是-D,打包成多文件放在一个文件夹),-w表明要打包成窗口型(与其对立的命令是-c,控制台型),[src1.py][src2.py][...]为你自己创建的应用程序源文件(src1.py必须是含__main__的主函数文件),-i指定图标文件。

PS D:\my_git_repo\pzh-py-com\bin> pyinstaller -F -w ..\src\main.py ..\src\formatter.py ..\src\win.py -i ..\img\pzh-py-com.ico

223 INFO: PyInstaller: 3.3.1
225 INFO: Python: 2.7.14
...
14707 INFO: Appending archive to EXE D:\my_git_repo\pzh-py-com\bin\dist\main.exe
14724 INFO: Building EXE from out00-EXE.toc completed successfully.

打包命令成功执行之后,便可以在\pzh-py-com\bin目录下看到如下生成的文件:

\pzh-py-com
           \bin                            --放置工程源代码文件
                  \build\                    --
                  \dist\main.exe             --可执行exe文件
                  \main.spec                 --spec文件

其中build文件夹存放的是PyInstaller在打包过程中生成的调试信息文件,dist文件夹下面的main.exe便是我们要的最终的可执行文件,main.spec是PyInstaller自动生成的命令解释文件,其实你在命令行里输入的命令首先被翻译放到.spec文件里,然后PyInstaller主要是根据.spec文件来打包的,不信你可以试着用pyinstaller main.spec命令重新再打包一次,得到的结果是一样的。下面是.spec文件里的内容,如果你对.spec文件了解,当然也可以自己创建.spec文件来进行打包。

# -*- mode: python -*-

block_cipher = None


a = Analysis(['main.py', 'formatter.py', 'win.py'],
             binaries=[],
             datas=[],
             hiddenimports=[],
             hookspath=[],
             runtime_hooks=[],
             excludes=[],
             win_no_prefer_redirects=False,
             win_private_assemblies=False,
             cipher=block_cipher)
pyz = PYZ(a.pure, a.zipped_data,
             cipher=block_cipher)
exe = EXE(pyz,
          a.scripts,
          a.binaries,
          a.zipfiles,
          a.datas,
          name='pzh-py-com',
          debug=False,
          strip=False,
          upx=True,
          runtime_tmpdir=None,
          console=False , icon='..\\img\\pzh-py-com.ico')

main.exe可执行文件已经生成好了,让我们试着打开使用一下,直接在\pzh-py-com\bin\dist\目录下打开这个文件发现报了如下错误,看起来是找不到图片路径,这是怎么回事?痞子衡其实在前面已经提到过,需要保证文件夹内图片相对路径与打包时相对路径一致,试着将main.exe放到\pzh-py-com\bin\目录下再打开看是不是正常了,因为这时候相对路径是一致的。大功告成了,最后将main.exe重命名为pzh-py-com.exe。

番外篇

正文中讲了,最终的pzh-py-com.exe必须配合pzh-py-com文件夹(主要是\img里的图片)一起使用,并且不能任意移动pzh-py-com.exe在pzh-py-com文件夹中位置,看起来这个pzh-py-com.exe还是有一些使用限制(当然你可以创建pzh-py-com.exe的快捷方式到桌面,你可以任意移动这个快捷方式,这算是一个workaround),能不能打破这个限制?只要一个pzh-py-com.exe文件即可,并且放到任意目录下都能运行?答案是有,可以参看这篇文章的思路 pyinstaller打包——图片资源无法显示问题,思路大概原理是事先将图片编码存到.py源文件里,这样在打包时便可将这个图片数据.py源文件直接打包进pzh-py-com.exe,后续pzh-py-com.exe在运行时首先将图片数据解码出来并在本地保存为临时图片,这样pzh-py-com.exe启动便可完成图片加载,等pzh-py-com.exe图片加载完成之后可以删除临时图片文件。思路有了,小伙伴赶紧动手试一试,这算是痞子衡在这个系列最后一课留给大家的一个课后作业。

至此,串口调试工具pzh-py-com诞生之打包发布痞子衡便介绍完毕了,掌声在哪里~~~

声明:本内容为作者独立观点,不代表电子星球立场。未经允许不得转载。授权事宜与稿件投诉,请联系:editor@netbroad.com
觉得内容不错的朋友,别忘了一键三连哦!
赞 2
收藏 3
关注 41
成为作者 赚取收益
全部留言
0/200
成为第一个和作者交流的人吧