其实有生成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纯手敲的,敲错了勿怪(●'◡'●) 对你有帮助的话点个赞呗