在anaconda环境中构建flask项目的exe文件


一、创建并激活虚拟环境

bash 复制代码
conda create -n flask_env python=3.9  # python版本根据项目需求安装
conda activate flask_env              # 激活环境

二、安装必要依赖

  • 推荐使用conda,pip没尝试过,但是deepseek给出了命令
bash 复制代码
conda install flask                   # 通过conda安装Flask
pip install pyinstaller              # 通过pip安装打包工具
# 或
conda install -c conda-forge pyinstaller  # 通过conda-forge安装

三、准备Flask应用(app.py

python 复制代码
from flask import Flask
app = Flask(__name__)

@app.route('/')
def hello():
    return "Hello, Packaged Flask App!"

if __name__ == "__main__":
    app.run(debug=False)

四、创建PyInstaller spec文件(可选)

bash 复制代码
pyi-makespec app.py --name myapp --onefile
  • 会生成一个. spec 文件,包含相关的配置项

五、关键配置调整

需要确保静态文件和模板被正确包含,修改.spec文件:

python 复制代码
# 在Analysis部分添加数据文件
a = Analysis(
    ['app.py'],
    pathex=[],
    binaries=[],
    datas=[('templates/*', 'templates'), ('static/*', 'static')],  # 添加资源目录
    ...
)
  • 同时需要在项目目录下新建 templates 和 static文件夹,如果已经有命名了作为 模板文件静态资源 的文件夹,请替换上述相关的名称到配置中

六、处理路径问题(重要!)

在Flask应用中修改资源路径:

python 复制代码
import sys
import os

def resource_path(relative_path):
    """ 获取资源的绝对路径"""
    if hasattr(sys, '_MEIPASS'):
        return os.path.join(sys._MEIPASS, relative_path)
    return os.path.join(os.path.abspath("."), relative_path)

# 使用示例
template_folder = resource_path('templates')
app = Flask(__name__, template_folder=template_folder)

七、执行打包命令

bash 复制代码
pyinstaller --onefile --name myapp --add-data "templates;templates" --add-data "static;static" app.py
  • 如果项目比较大,可能打包构建的时间会比较长
  • 打包完成后会生成以下两个文件夹,生成的exe文件为 myapp.exe
  • 双击运行程序,如果出现相关的文件缺失,将缺失文件复制到dist文件夹下即可

八、验证打包结果

bash 复制代码
cd dist
./myapp.exe  # Windows直接双击运行
  • 接下来就可以到服务器中做部署操作了

常见问题解决

  1. 文件体积过大

    • 使用conda clean --all清理缓存
    • 添加--exclude-module排除不需要的模块
  2. 运行时提示缺失文件

    bash 复制代码
    pyinstaller --hidden-import=werkzeug.serving ...
  3. 杀毒软件误报

    • 使用代码签名证书
    • 添加白名单
  4. 控制台窗口隐藏

    bash 复制代码
    pyinstaller --noconsole ...

完整打包示例命令

bash 复制代码
conda activate flask_env
pyinstaller --onefile --name MyFlaskApp \
--add-data "templates;templates" \
--add-data "static;static" \
--hidden-import=jinja2 \
--hidden-import=werkzeug.urls \
app.py

感慨一句:deepseek 真的好厉害!!!

相关推荐
七老板的blog3 小时前
从持久化任务到多 Agent 协作
python·学习·ai
XGeFei3 小时前
python中子线程与主线程的关系
开发语言·python
Chase_______3 小时前
【Java杂项】final 关键字详解:变量、方法、类限制与引用可变性
java·开发语言·python
我材不敲代码3 小时前
Python venv 虚拟环境从入门到精通 + uv 高性能替代工具实战指南
开发语言·python·uv
l1t3 小时前
DeepSeek总结的使用实体-组件-系统和基于存在性处理进行Python编程18-20
开发语言·python
零梦ing3 小时前
Claude Code 升级后 DeepSeek API 报错 messages[x].role: unknown variant system 终极解决方案
python·claude code·deepseek api 代理
Eiceblue4 小时前
Python 操作 Excel:数据分组、分类汇总与取消分组全解
开发语言·python·excel
暴躁小师兄数据学院4 小时前
【AI大模型应用开发工程师特训笔记】第04讲(第9章):文件目录操作
人工智能·笔记·python
TechWayfarer5 小时前
IP精准定位服务在快递网点规划中的应用:如何用客户位置数据辅助选址
大数据·网络·python·tcp/ip·交通物流
CSND7405 小时前
零基础学Python合集---3:字符串的定义和常用方法
人工智能·python