pyinstaller 将python程序打包成exe之后,运行无法生成log文件,解决方案

其实有生成log文件,但是不是在exe文件所在的文件夹内。而是会在C:Users/用户/你的用户名/AppData/Local/Temp/_MEI*目录下,在结束运行后,这个路径文件夹会被删除。

我看网上的解决方案是:

if getattr(sys, 'frozen', False):
    pathname = sys._MEIPASS
else:
    pathname = os.path.split(os.path.realpath(__file__))[0]

我试过,有点用但不多,最简单的解决方案是:

在python程序里直接用sys.argv获取当前程序所在路径,然后拼接你的日志文件即可,如果日志文件不存在则自动创建:

# -*- coding:utf-8 -*-

import sys
import logging
import os

if __name == '__main__':
  
# argv:即所谓的参数变量,这个变量保存着你运行Python脚本时传递给Python脚本的参数 
# argv[0]即表示自身所在路径 比如:D:/dist/a.exe
exe_path = sys.argv[0]
print("程序所在路径:"+exe_path)


# 日志文件所在目录
dir_path = os.path.dirname(exe_path)

# 为了确保目录存在,再校验一手 目录不存在就自动创建
if not os.path.exists(dir_path)
    os.makedirs(dir_path)

# 拼接日志文件
logs_file_path = os.path.join(dir_path, 'data.log')

# 如果日志文件不存在就自动创建
if not os.path.exists(logs_file_path):
    open(logs_file_path, 'w')

# 接下来就是咱们的logging日志文件选择器 即可以在控制台打印,又可以写入文件
# 这段代码其实就是为了将exe打印的日志写入一个文件
# 而且测试的时候又想在pycharm控制台看到日志,所以这么写,网上一搜一大堆
logger = logging.getLogger("mylogger")
logger.setLevel(logging.INFO)
sh = logging.StreamHandler()
sh.setLevel(logging.DEBUG)
sh.setFormatter(logger.Formatter("%(asctime)s - %(levelname)s - %(message)s"))

fh = logging.FileHandler(logs_file_path)
fh.setLevel(logger.DEBUG)
fh.setFormatter(logger.Formatter("%(asctime)s - %(levelname)s - %(message)s"))
logger.addHandler(sh)
logger.addHandler(fh)

logger.info("程序所在路径:" + exe_path)
logger.info("日志文件存放路径:" + dir_path)

代码是在csdn纯手敲的,敲错了勿怪(●'◡'●) 对你有帮助的话点个赞呗

### PyInstaller 打包 exe 文件程序无法启动的解决方案 当使用 PyInstaller 打包 Python 程序exe 文件后遇到无法启动的情况,可能由多种原因引起。以下是几种常见问题及其对应的解决方法。 #### 1. 缺少依赖项 如果应用程序依赖于某些外部库或资源文件,在打包过程中未能正确包含这些依赖项,则可能导致生成的应用程序无法正常工作。确保所有必需模块都已安装并被 PyInstaller 正确识别和嵌入到最终产品中[^1]。 对于复杂项目而言,可以尝试通过 `--hidden-import` 参数显式指定隐藏导入: ```bash pyinstaller --hidden-import=module_name your_script.py ``` #### 2. 控制台模式与 GUI 应用冲突 有时开发者会发现自己的图形界面应用在转换 .exe 后总是弹出控制台窗口。这是因为默认情况下 PyInstaller 使用的是控制台子系统来创建可执行文件。为了防止这种情况发生,可以在调用 PyInstaller 的时候加上 `-w` 或者 `--noconsole` 参数以指示其构建 Windows GUI 子系统的二进制文件而不是控制台版本。 ```bash pyinstaller -F -w your_gui_app.py ``` #### 3. 日志记录路径错误 部分应用程序可能会因为找不到预期的日志存储位置而失败。由于临时目录 `_MEI*` 中的数据会在进程结束后自动清理掉,因此建议修改日志保存逻辑使其指向固定的位置,比如用户的文档文件夹或其他持久化区域[^3]。 可以通过调整代码中的 logging 配置实现这一点: ```python import os from pathlib import Path logs_dir = str(Path.home() / "Documents" / "MyAppLogs") if not os.path.exists(logs_dir): os.makedirs(logs_dir) logging.basicConfig( filename=os.path.join(logs_dir, 'app.log'), level=logging.DEBUG, format='%(asctime)s %(levelname)s:%(message)s' ) ``` #### 4. 版本兼容性问题 不同版本间的差异也可能造不兼容现象。确认所使用的 PyInstaller 及其他相关工具链(如 setuptools)处于最新稳定状态,并且与源码环境相匹配[^2]。 更新 pip 和 pyinstaller: ```bash pip install --upgrade pip pip install --upgrade pyinstaller ``` 重新编译前清除旧版缓存数据有助于排除潜在干扰因素: ```bash rm -rf build dist __pycache__ pyclean . ``` 以上措施能够有效提高功率,但仍需针对具体情况做适当调试优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值