簡體   English   中英

PyInstaller exe 文件不會創建日志文件

[英]PyInstaller exe file doesn't create log file

我正在嘗試使我的腳本可執行,以便我可以將其發送給我的同事。 我正在使用PyInstaller

pyinstaller --onefile main.py

這會創建兩個文件夾。 當我打開 dist/main.exe 時,出了點問題,但我不知道是什么,因為它沒有創建日志文件。 我不明白為什么。 當我運行main.py ,會立即創建日志文件。

你能檢查一下嗎?

# coding=utf-8
from __future__ import print_function
import csv
import os
import time
import logging
import sys
import traceback
from spider import is_connected
from database import Database
filename = os.path.join(os.path.dirname(os.path.realpath(__file__)), 'log.log')
logging.basicConfig(filename=filename, level=logging.INFO, filemode='w')

logger = logging.getLogger(__name__)
def printProgressBar(iteration, total, prefix='', suffix='', decimals=1, length=100, fill=u'█'):
    """
    Call in a loop to create terminal progress bar
    @params:
        iteration   - Required  : current iteration (Int)
        total       - Required  : total iterations (Int)
        prefix      - Optional  : prefix string (Str)
        suffix      - Optional  : suffix string (Str)
        decimals    - Optional  : positive number of decimals in percent complete (Int)
        length      - Optional  : character length of bar (Int)
        fill        - Optional  : bar fill character (Str)
    """
    percent = ("{0:." + str(decimals) + "f}").format(100 * (iteration / float(total)))
    filledLength = int(length * iteration // total)
    bar = fill * filledLength + '-' * (length - filledLength)
    print('\r%s |%s| %s%% %s' % (prefix, bar, percent, suffix))
    # Print New Line on Complete
    if iteration == total:
        print()


if __name__ == '__main__':
    print(os.path.join(os.path.dirname(os.path.realpath(__file__)), 'log.log'))
    logger.info('Download started...')
    connected = is_connected()
    logger.info('Checking connection... {}'.format(connected))
    if not connected:
        logger.info('Program closed - no connection...')
        sys.exit()
    db = Database()
    if not os.path.isdir("output"):
        print('Nenasla sa zlozka "output"...')
        logger.info('No output folder')
        input()
        sys.exit()
    if not os.path.isdir("csv"):
        print('Nenasla sa zlozka "csv"...')
        logger.info('No csv folder')
        input()
        sys.exit()

    print('Spracovavanie suboru "input.csv"...')
    filename = 'output_{}.csv'.format(time.strftime("%Y%m%d-%H%M%S"))
    try:
        with open('csv/input.csv') as f:
            with open('output/'+filename, 'wb') as o:
                reader = csv.DictReader(f)
                reader.fieldnames.append('VAT added')
                writer = csv.DictWriter(o, fieldnames=reader.fieldnames)
                writer.writeheader()
                r_list = list(reader)
                rows = len(r_list)
                for n, line in enumerate(r_list):
                    if n>0:
                        printProgressBar(n,rows)
                        code = line['Lot number'].strip()
                        vat = db.get_or_set_vat(code)
                        logger.info('outer vat')
                        logger.info(vat)
                        logger.info('YES' if vat else 'NO' if vat == False else 'UNKNOWN')
                        line['VAT added'] = 'YES' if vat else 'NO' if vat == False else 'UNKNOWN'
                        writer.writerow(line)
    except IOError as e:
        print(e)
        logger.info('IOError')
        logger.info(traceback.format_exc())
        print('Chyba: zrejme nenaslo subor "input.csv" - skontrolujte nazov suboru v zlozke csv')
        input()
        sys.exit()
    print()
    print('Koniec stahovania - {}'.format(filename))
    input()

當您凍結應用程序時,文件可能位於sys._MEIPASS

這是我在我的應用程序中測試的一個小例子:

 if hasattr(sys, "_MEIPASS"):
            base_dir = os.path.join(sys._MEIPASS)
            print(base_dir)
            print(sys.argv[0])
>> C:\Users\Hendr\AppData\Local\Temp\_MEI986122
>> C:\Users\Hendr\Documents\coding_stuff\dist\test.exe

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM