百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Python一键打包为windows的exe文件,无需安装python环境即可执行

gudong366 2025-05-15 18:21 9 浏览

一、为什么要将Python打包为 exe?

在实际应用中,我们希望Python程序能在没有安装Python环境的电脑上直接运行。将Python代码打包为exe可执行文件,不仅能解决环境依赖问题,还便于程序的分发和部署。

二、常用打包工具及核心函数介绍

1. pyinstaller

pyton程序版本需要Python <3.14, >=3.8。

安装:pip install pyinstaller -i
https://mirrors.aliyun.com/pypi/simple/

打包:pyinstaller [options] script.py

[options]为打包选项,script.py为打包的Python脚本。

  • -F:打包成单个可执行文件(推荐使用,方便文件分发)。
  • -w:窗口化模式,隐藏命令行窗口(适用于图形界面程序)。
  • -i:指定程序图标(格式如.ico)。

案例

# 打包成单个可执行文件
pyinstaller -F hello.py
# 打包图形界面程序,隐藏命令行窗口并指定图标
pyinstaller -F -w -i icon.ico gui_app.py

当然还有其他一些参数,参见附录中的介绍。

2. cx_Freeze

python版本需要Python >=3.9。

安装:pip install cx_Freeze -i
https://mirrors.aliyun.com/pypi/simple/

打包:需要在项目目录下创建setup.py文件进行配置,然后在命令行执行python setup.py build进行打包,最后在build目录下生成可执行exe文件。

from cx_Freeze import setup, Executable
setup(
name="MyApp",
version="1.0",
description="My Python application",
executables=[Executable("main.py")]
)

3. py2exe

py2exe用于Windows平台,适配python版本:Python < 3.12, >=3.8

安装:pip install py2exe -i
https://mirrors.aliyun.com/pypi/simple/

打包:需要在项目目录下创建setup.py文件进行配置,然后在命令行执行python setup.py py2exe进行打包,最后在当前目录下生成可执行exe文件。

from distutils.core import setup
import py2exe
setup(
console=["main.py"]
)

三、实用案例详解

我们将之前文章介绍的使用pywebio做数学题的web程序打包为一个exe可执行文件。(文章:Python中PyWebIO:无须搞懂前端知识,也能5分钟快速搭建Web应用

我们新建一个pywebio-math.py文件,放入程序

from pywebio.pin import put_input, pin, pin_wait_change
from pywebio.output import *
from pywebio.input import *
import random
from pywebio.session import hold


class calcMath:

    def __init__(self, num):
        self.num = num  # 题目的数量
        self.finish_switch = False  # 答案提交后 置为True

    def mathproblem(self):
        """
        根据题目的数量,生成100以内的的加减混合运算的数学题的字典并返回;
        字典的key是题目,value是答案
        """
        math_problem = {}
        num = 1
        while num <= self.num:
            num1 = random.randint(1, 99)
            num2 = random.randint(1, 99)
            num3 = random.randint(1, 99)
            if num1 + num2 - num3 < 100 and num1 + num2 - num3 > 0 and num1 + num2 < 100:
                num += 1
                result = num1 + num2 - num3
                key_name = f'{num1} + {num2} - {num3}'
                math_problem[key_name] = result
        return math_problem

    def submit_result(self):
        # 弹出对话框  是否确认提交  点击提交会触发生成答案信息
        popup('确定提交吗?', [
            put_buttons(['确定'], onclick=lambda _: self.set_witch()),
            put_buttons(['取消'], onclick=lambda _: close_popup())
        ])

    def set_witch(self):
        self.finish_switch = True
        try:
            close_popup()
        except Exception as e:
            print(e)

        if self.finish_switch:
            # 生成答案信息 并输出
            self.analyse_result(inputs_str, origin_answer_result, new_answer_result)
            self.finish_switch = False

    def analyse_result(self, inputs_str, origin_answer_result, new_answer_result):

        """
        分析答案
        :param inputs_str: 包含题目信息的列表
        :param origin_answer_result:  真实答案
        :param new_answer_result:     答题的答案
        : return:
        """

        rightnum = 0  # 做对的题目数
        for num in range(len(inputs_str)):
            # 判断输入为空或者不为数字时,认为题目做错了
            if not new_answer_result[num] or not str(new_answer_result[num]).isdigit():
                put_text(
                    f'这个题 {inputs_str[num]} 做错了, 提交的答案是{new_answer_result[num]} ,正确答案是{origin_answer_result[num]}')
            else:
                # 当真实答案和做出的答案一致时,数字加1
                if int(origin_answer_result[num]) == int(new_answer_result[num]):
                    rightnum += 1
                else:
                    put_text(
                        f'这个题 {inputs_str[num]} 做错了, 提交的答案是{new_answer_result[num]} ,正确答案是{origin_answer_result[num]}')
        # 汇总最后的结果输出到web页面上
        put_text(f'--总共{len(inputs_str)},做对了{rightnum}题,做错了{len(inputs_str) - rightnum}题')

    def start_do_math(self):
        """
        执行函数
        :return:
        """
        # 生成数学题字典 key是题目,value是答案
        mathdict = self.mathproblem()

        # 生成pywebio的input函数用到的输入数学题信息列表: 展示的是题目信息
        inputs_str = [f'{key} = ( )' for key in mathdict.keys()]

        # 生成对应的答案列表 用于跟答题时写的答案做对比
        origin_answer_result = [mathdict[key] for key in mathdict.keys()]

        # 调用pywebio的pin.put_input函数 和pin_wait_change 监听输入的答案 输入后进行下一个题目
        keys = [f'num{i + 1}' for i in range(self.num)]
        for i in range(self.num):
            put_input(keys[i], label=f'第{i + 1}题 请在下方输入答案(输入后不支持修改)\n {inputs_str[i]}')
            pin_wait_change(keys[i], timeout=1000)  # 监听输入 有输入后才进行下一次循环

        # 提交按钮  点击后弹出确认对话框
        put_button('submit', onclick=self.submit_result)
        # 提取提交的答案
        new_answer_result = [getattr(pin, key) for key in keys]
        # print(new_answer_result)
        return inputs_str, origin_answer_result, new_answer_result


num = input('请输入题目的数量:',type=NUMBER)
math1 = calcMath(num)  #实例化
inputs_str, origin_answer_result, new_answer_result = math1.start_do_math()
#保持会话 直到关闭浏览器
hold()

然后我们使用上述介绍的方法,打包为一个exe文件,打包后我们双击exe文件,执行效果跟通过python执行是一样的。

我们使用cx_Freeze进行打包,在程序目录中见一个setup.py文件,然后填入参数

from cx_Freeze import setup, Executable
setup(
    name="MyApp",
    version="1.0",
    description="My Python application",
    executables=[Executable("pywebio-math.py")]
)

目录内容如下:


然后再命令行执行:

最后在build目录生成一个exe文件

我们双击pywebio-math.exe然后执行。

四、附录

pyinstaller的其他一些参数介绍:

1. -p, --paths 添加额外的模块搜索路径。当你的程序依赖的模块不在默认搜索路径中时,可通过该参数指定路径,PyInstaller找到相关模块。

pyinstaller -F -p ./my_lib script.py

PyInstaller在打包时就会到./my_lib路径下查找所需模块。

2. --add-data 将非 Python 文件(如图片、配置文件等)添加到打包结果中。在 Windows 系统中,参数格式source;dest;在 Linux 和 macOS 系统中,参数格式source:dest。其source是源文件或目录路径,dest是打包后文件在可执行文件中的存放路径。

若你的程序使用icon.png图片,且该图片在./images目录下,希望打包后图片存放在./assets目录下,在 Linux 或 macOS 系统中可使用以下命令:

pyinstaller -F --add-data "images/icon.png:assets" script.py

在 Windows 系统中则为:

pyinstaller -F --add-data "images/icon.png;assets" script.py

3. --exclude-data-dir 从打包结果中排除指定的数据目录,可用于减少打包文件体积,排除不必要的数据。

如果你的项目中./temp_data目录下的数据在程序运行时不需要,可使用该参数排除:

pyinstaller -F --exclude-data-dir temp_data script.py

4. -D, --onedir 将程序打包成一个目录,目录中包含可执行文件和所有依赖文件。相比-F生成单个可执行文件,这种模式便于调试和查看文件结构。

pyinstaller -D script.py

打包完成后,dist目录下会生成一个以脚本名称命名的文件夹,里面存放着可执行文件和相关依赖。

5. --clean 在打包前清理掉之前打包过程中产生的临时文件和缓存,避免旧的打包残留影响本次打包,确保打包的纯净性。

pyinstaller --clean -F script.py

6. --upx-dir 指定UPX压缩工具的路径。UPX 是一款高效的可执行文件压缩器,使用--upx-dir参数并配合--upx-exclude等参数,可以压缩打包后的可执行文件,减小文件体积。

pyinstaller --upx-dir /usr/local/upx -F your_script.py

7. --debug 启用调试模式,可分为--debug=imports、--debug=bootloader等不同级别。--debug=imports会在打包过程中输出详细的模块导入信息,有助于排查模块导入相关问题;--debug=bootloader则输出引导加载器相关的调试信息。

pyinstaller --debug=imports -F script.py

相关推荐

梦幻诛仙12职业1亿元宝版本架设教程(包含资源下载)

架设教程:1;上传脚本zx到bin文件夹,给权限chmod-R777/bin2;输入zx安装宝塔面板输入对应序号,中途输入Y继续3;安装好之后,会给个宝塔地址及账号密码,复制地址...

Java零基础入门,科普Java你应该了解什么

最近很多人问我想学Java但是一点基础没有,网上看了一堆学习线路图还是无从下手。今天耗时3小时整理了一套保姆级的Java入门教程,建议收藏按照线路图一点点学习。一、Java的概况Java是1995年6...

01.Java发展历史(java发展历史简要)

1.Java发展历史Java由SunMicrosystems公司(现为Oracle公司)的JamesGosling及其团队在1991年开发,最初命名为"Oak",后改名为"...

Ubuntu16.04.1安装Java8(ubuntu终端安装java)

上篇文章讲解了怎么在Windows下安装Java8《Windows10安装Java8》,这里讲解下怎么在Linux下安装Java。由于之前已经安装了Ubuntu16.04.1《VmwareWorkst...

性能测试能力提升-JVM GC监控和优化

一、背景接着上一篇的知识:性能测试能力提升-JVMGC原理,本篇文章,我们将主要介绍JVMGC监控和优化相关的知识:命令行方式监控GC图形化方式监控GC什么时候需要开始GC优化?GC优化的目的GC...

Spring Boot Jar 包秒变 Docker 镜像实现多环境部署

你是否在互联网大厂后端开发工作中,遇到过这样的困扰?当完成一个SpringBoot项目开发,准备将Jar包部署到不同环境时,却发现各个环境依赖不同、配置复杂,部署过程繁琐又容易出错,不仅耗费...

「JDK 11」关于 Java 模块系统,看这一篇就够了

继2014年3月Java8发布之后,时隔4年,2018年9月,Java11如期发布,其间间隔了Java9和Java10两个非LTS(LongTermSupp...

对Java学习的10条建议(对java的认识和理解)

不少Java的初学者一开始都是信心满满准备迎接挑战,但是经过一段时间的学习之后,多少都会碰到各种挫败,以下北风网就总结一些对于初学者非常有用的建议,希望能够给他们解决现实中的问题。Java编程的准备:...

JAVA入门教程-第1章 概述(java入门指南)

大道至简-JAVA入门教程在本教程中,你将学习Java语言的基础知识。Java基础内容涵盖:Java基础概念、Java词法结构、Java数组、Java流程控制、Java字符串、Java...

推荐一款Java音频视频编码器,很赞

Jave2是什么JAVE2(Java音频视频编码器)库是ffmpeg项目上的Java包装器。开发人员可以利用JAVE2将音频和视频文件从一种格式转码为另一种格式。在示例中,您可以将AVI文件转换为MP...

【JAVA教程】JAVA入门及开发环境安装

一、Java开发环境概述Java开发需要三个核心组件:JDK(JavaDevelopmentKit)-Java开发工具包,开发、编译、调试Java程序JRE(JavaRuntimeE...

Windows和Linux环境下的JDK安装教程

JavaDevelopmentKit(简称JDK),是Java开发的核心工具包,提供了Java应用程序的编译、运行和开发所需的各类工具和类库。它包括了JRE(JavaRuntimeEnviro...

记Tomcat优化方案(tomcat优化的几种方法)

Tomcat服务吞吐量评估方案问题:评估方案在一台8核16G的linux服务器上,使用tomcat容器部署服务。在正常情况下如何评估这个tomcat服务可处理的连接数,即服务的吞吐量,请在正常情况下考...

JVM GC诡异问题排查,k8s差点害死我……

前言本文将通过一个真实的生产环境案例,详细展示如何系统性地排查和解决JVM垃圾收集问题。这个案例涵盖了从问题发现、分析诊断到最终解决的完整过程,对于理解JVM调优实战具有重要的参考价值。系统背景我们的...

Thorium Reader - 功能强大的跨平台免费电子书阅读器

在日常阅读日益普及的今天,选择一款合适的电子书阅读器至关重要。ThoriumReader作为一款独具特色的阅读应用,正逐渐在众多同类产品中崭露头角,为用户带来了卓越的阅读体验。  跨平台的便捷性...