手动制作python的exe可执行程序 转

本文介绍如何使用Python手动实现类似py2exe的功能,将Python程序打包为exe文件,包括原理、步骤和代码实现,简化部署过程。

高手不用py2exe啊,呵呵

转自http://blog.youkuaiyun.com/rlj021/archive/2007/11/21/1896764.aspx

Python没有内建一个编译为exe的功能。给python程序的部署带来不少的麻烦。

所以就会出现一些py2exe之类的很不错的工具,用于自动把.py文件编译为.exe文件。

最近抽空研究了一下手动实现类似py2exe的功能,希望加强对python的了解。

结果还相当不错。把结果记录下来,与大家共享。


1.1. 原理

文中所描述的方法,基于python的以下几个功能

1. python程序运行时,会在sys.path指定的路径中查找库文件。

2. python从2.3开始,支持从zip文件中import库(支持.py,.pyc和.pyo,但不支持.pyd)

3. python提供C API,让c语言的程序,可以很方便的调用python的程序


1.2. 实际步骤

注:假设python安装在c:\python25目录中,最后的可执行文件放到d:\dist目录中

1. 先去c:\python25\Lib目录,把所有文件都复制出来,比如复制到d:\pythonlib目录中

2. 开一个cmd窗口,进入d:\pythonlib目录中,运行 python -OO compileall.py -f . 把lib中的.py文件都编译成.pyo文件

3. 删除d:\pythonlib目录中所有的.py和.pyc文件,因为我们只要有.pyo文件就可以让这些库运行了。

4. 删除目录中所有用不着的文件,比如curses,test,idlelib,msilib等,以减少生成文件的体积。

5. 把这些库打包成一个zip文件,比如stdlib.zip,放到d:\dist目录中

6. 把c:\python25\dlls目录中的.pyd和.dll文件,复制到d:\dist\dlls目录中,当然,删除不可能用到的一些文件_msi.pyd,_ssl.pyd等等,可以减少文件的体积

7. 把自己写的程序,也按步骤2至步骤5所说的方法,打成一个mysrc.zip包,放到d:\dist目录中。 注意:自己写的程序的入口应该是main.pyo文件

8. 用以下C程序编译出一个可执行文件,比方说叫runpy.exe,也放到d:\dist中。

#include <Python.h>
#include <Windows.h>
int main()
{
        // 得到当前可执行文件所在的目录
        char szPath[10240];
        char szCmd[10240];
        GetModuleFileName(NULL, szPath, sizeof(szPath));
        char* p = strrchr(szPath, '\\');
        if (p == NULL)
        {
                printf("Get module file name error!\n");
                return -1;
        }
        *p = 0;
        // 把sys.path设定为['.', '自己的源代码zip文件', '标准库zip文件', 'dll目录']
        // 然后调用main模块
        sprintf(szCmd,
                "import sys\n"
                "sys.path=['.', r'%s\\mysrc.zip', r'%s\\stdlib.zip', r'%s\\dlls']\n"
                "import main\n",
                szPath, szPath, szPath);
        Py_Initialize();
        PyRun_SimpleString(szCmd);
        return 0;
}

9. 把python25.dll放到d:\dist目录中。


1.3. 结束语

这样来,d:\dist目录中,一共只有4个文件加一个目录:

dlls目录:用于存放所有的dll文件和pyd文件

stdlib.zip文件:用于存放所有的python的.pyo文件格式的标准库

mysrc.zip文件:用于存放自己写的程序。注意,自己写的程序的入口在main.pyo中。

runpy.exe文件:程序的启动文件,启动后会设定python的sys.path,然后调用main模块

python25.dll文件:python的核心dll,runpy.exe依赖于这个dll

哈哈,相当的简洁明了吧。一共才4个文件一个目录,5MB都不到哦。

注:当然,这种打包方式第一次做的时候比较麻烦,但之后就可以只要把自己的程序打包就好了,其它的不用变。

而且,如果自己的程序经常做改动的话,自己的程序也可以不打包,直接放到d:\dist中,反正runpy.exe启动程序的时候,只要能正常运行import main就可以了。

下载方式:https://pan.quark.cn/s/a4b39357ea24 布线问题(分支限界算法)是计算机科学和电子工程领域中一个广为人知的议题,它主要探讨如何在印刷电路板上定位两个节点间最短的连接路径。 在这一议题中,电路板被构建为一个包含 n×m 个方格的矩阵,每个方格能够被界定为可通行或不可通行,其核心任务是定位从初始点到最终点的最短路径。 分支限界算法是处理布线问题的一种常用策略。 该算法与回溯法有相似之处,但存在差异,分支限界法仅需获取满足约束条件的一个最优路径,并按照广度优先或最小成本优先的原则来探索解空间树。 树 T 被构建为子集树或排列树,在探索过程中,每个节点仅被赋予一次成为扩展节点的机会,且会一次性生成其全部子节点。 针对布线问题的解决,队列式分支限界法可以被采用。 从起始位置 a 出发,将其设定为首个扩展节点,并将与该扩展节点相邻且可通行的方格加入至活跃节点队列中,将这些方格标记为 1,即从起始方格 a 到这些方格的距离为 1。 随后,从活跃节点队列中提取队首节点作为下一个扩展节点,并将与当前扩展节点相邻且未标记的方格标记为 2,随后将这些方格存入活跃节点队列。 这一过程将持续进行,直至算法探测到目标方格 b 或活跃节点队列为空。 在实现上述算法时,必须定义一个类 Position 来表征电路板上方格的位置,其成员 row 和 col 分别指示方格所在的行和列。 在方格位置上,布线能够沿右、下、左、上四个方向展开。 这四个方向的移动分别被记为 0、1、2、3。 下述表格中,offset[i].row 和 offset[i].col(i=0,1,2,3)分别提供了沿这四个方向前进 1 步相对于当前方格的相对位移。 在 Java 编程语言中,可以使用二维数组...
源码来自:https://pan.quark.cn/s/a4b39357ea24 在VC++开发过程中,对话框(CDialog)作为典型的用户界面组件,承担着与用户进行信息交互的重要角色。 在VS2008SP1的开发环境中,常常需要满足为对话框配置个性化背景图片的需求,以此来优化用户的操作体验。 本案例将系统性地阐述在CDialog框架下如何达成这一功能。 首先,需要在资源设计工具中构建一个新的对话框资源。 具体操作是在Visual Studio平台中,进入资源视图(Resource View)界面,定位到对话框(Dialog)分支,通过右键选择“插入对话框”(Insert Dialog)选项。 完成对话框内控件的布局设计后,对对话框资源进行保存。 随后,将着手进行背景图片的载入工作。 通常有两种主要的技术路径:1. **运用位图控件(CStatic)**:在对话框界面中嵌入一个CStatic控件,并将其属性设置为BST_OWNERDRAW,从而具备自主控制绘制过程的权限。 在对话框的类定义中,需要重写OnPaint()函数,负责调用图片资源并借助CDC对象将其渲染到对话框表面。 此外,必须合理处理WM_CTLCOLORSTATIC消息,确保背景图片的展示不会受到其他界面元素的干扰。 ```cppvoid CMyDialog::OnPaint(){ CPaintDC dc(this); // 生成设备上下文对象 CBitmap bitmap; bitmap.LoadBitmap(IDC_BITMAP_BACKGROUND); // 获取背景图片资源 CDC memDC; memDC.CreateCompatibleDC(&dc); CBitmap* pOldBitmap = m...
从给定引用中未直接获取使用Python实现小红书推流的方法。不过,一般来说,使用Python实现小红书推流可以考虑以下通用步骤和相关技术: ### 模拟登录 可以使用`selenium`库模拟浏览器操作来登录小红书账号。示例代码如下: ```python from selenium import webdriver from selenium.webdriver.common.by import By import time # 设置浏览器驱动路径 driver = webdriver.Chrome() # 打开小红书登录页面 driver.get('https://www.xiaohongshu.com/login') # 等待用户手动完成登录操作 time.sleep(30) ``` ### 内容准备 按照小红书的内容规范准备好要推流的文本、图片或视频等内容。如果是要将内容以Markdown格式准备,可参考如下类似引用[1]中的操作: ```python # 打开文件用于写入内容 with open('xiaohongshu_content.md', 'w', encoding='utf-8') as file: # 标题栏:居中、设置字体大小、加粗 file.write("<div align='center'><font size='30'><b>深圳大事件(7月16日)</b></font></div>") # 小号标题 file.write("##【新闻】\n\n") # 关键内容标为红色,加粗,比如:金额 file.write("92号汽油:<font color=red><b>7.60元</b></font>元\n\n") # 空格及换行 file.write("...&nbsp;&nbsp;&nbsp;&nbsp;...\n\n") ``` ### 推流操作 使用`selenium`模拟在小红书页面上进行发布操作,例如点击发布按钮、上传内容等。示例代码如下: ```python # 找到发布按钮并点击 publish_button = driver.find_element(By.CSS_SELECTOR, 'button.publish-button') publish_button.click() # 上传图片或视频等内容(这里假设是上传图片) image_upload_input = driver.find_element(By.CSS_SELECTOR, 'input[type="file"]') image_upload_input.send_keys('path/to/your/image.jpg') # 输入标题和正文内容 title_input = driver.find_element(By.CSS_SELECTOR, 'input.title-input') title_input.send_keys('你的标题') content_textarea = driver.find_element(By.CSS_SELECTOR, 'textarea.content-textarea') with open('xiaohongshu_content.md', 'r', encoding='utf-8') as file: content = file.read() content_textarea.send_keys(content) # 点击最终发布按钮 final_publish_button = driver.find_element(By.CSS_SELECTOR, 'button.final-publish-button') final_publish_button.click() ``` ### 自动化流程优化 可以结合`schedule`库实现定时推流,示例代码如下: ```python import schedule import time def push_to_xiaohongshu(): # 这里调用上述模拟登录、内容准备和推流操作的函数 pass # 每天早上9点执行推流操作 schedule.every().day.at("09:00").do(push_to_xiaohongshu) while True: schedule.run_pending() time.sleep(1) ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值