【问题标题】:logger cannot find file记录器找不到文件
【发布时间】:2015-11-15 00:24:33
【问题描述】:

当我输入这个输入命令时出现这个错误:

$ python3.4 cron_e2e.py -f test_web_events -E ctg-clickstream testbrad

错误:

$ python3.4 cron_e2e.py -f test_web_events -E ctg-clickstream testbrad
Traceback (most recent call last):
  File "cron_e2e.py", line 421, in <module>
    sys.exit(main(sys.argv))
  File "cron_e2e.py", line 368, in main
    log.addHandler(logging.FileHandler(logfile))
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/logging/__init__.py", line 1006, in __init__
    StreamHandler.__init__(self, self._open())
  File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/logging/__init__.py", line 1030, in _open
    return open(self.baseFilename, self.mode, encoding=self.encoding)
FileNotFoundError: [Errno 2] No such file or directory: '/Users/bli1/Development/QE/chun-qe-trinity-functional/qe/tests/qe/logs/testbrad_8_21_2015_cron.log'

错误出现在这一行:

log.addHandler(logging.FileHandler(logfile))

不太确定我的代码没有在哪里为我创建日志文件

代码:

def main(argv):
    "Test"
    exit_code = 0
    global me; me = os.path.basename(argv[0]) # name of this program
    global mydir; mydir = os.path.dirname(os.path.abspath(__file__))
    parser = argparse.ArgumentParser(description=main.__doc__)
    parser.add_argument("-f", "--functional_test", metavar="FUNCTEST",
                        dest="functest", help="Type of functional test")
    parser.add_argument("-p","--phase", action="append",
                        metavar="POST|HDFS|HIVE|ALL", dest="phase",
                        help="phase of test to run")
    parser.add_argument("-t", "--testfile", metavar="TESTFILE",
                        dest="testfile", default=os.path.join(mydir, "resources/cron.json"),
                        help="file with test commands")
    parser.add_argument("-E","--Event", metavar="EVENTNAME",
                        dest="event_names", action="append",
                        help="[repeatable] topic to which to post")
    parser.add_argument("runtag",
                        metavar="RUNTAG",
                        help="run tag for this run")
    args = parser.parse_args(args=argv[1:])  # will exit on parse error
    log = logging.getLogger(me)
    log.setLevel(logging.INFO)
    dt = datetime.datetime.utcnow()
    logfile = "qe/logs/" + (args.runtag + "_{}_{}_{}".format(dt.month, dt.day, dt.year) + "_cron.log")

    pdb.set_trace()
    if isinstance(logfile, str):
        if os.path.exists(logfile):
            os.remove(logfile)
        # logging.FileHandler() returns FileHandler class, the file is opened and used as the stream for logging
        log.addHandler(logging.FileHandler(logfile))
    console = logging.StreamHandler(sys.stderr); console.setLevel(logging.WARNING); log.addHandler(console)

【问题讨论】:

  • 你确定traceback最后一行的路径存在吗?你不想改用logfile = '../logs/' + ..... 吗?

标签: python python-3.x logging


【解决方案1】:

anand-s-kumar answer 很棒,但现在有一个更短的替代解决方案,使用pathlib

import pathlib

pathlib.Path('qe/logs/').mkdir(parents=True, exist_ok=True)

【讨论】:

    【解决方案2】:

    问题是您定义要转到的日志文件的目录 - "qe/logs/" - 不存在。

    默认情况下FileHandler 的模式是'a',这意味着如果日志文件存在,它将打开它并在最后开始追加,否则它将创建文件。

    但是 FileHandler 只会在日志文件不存在的情况下创建它,如果目录不存在则不会创建目录,如果目录不存在,它会像你一样抛出错误。

    您需要手动或以编程方式自己创建目录。如果你想以编程方式创建目录,你可以使用 - os.makedirs() - 这将 -

    创建包含叶目录所需的所有中间级目录。

    例子-

    import os, os.path
    if not os.path.exists("qe/logs/"):
        os.makedirs("qe/logs/")
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-10-08
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-02-13
      • 1970-01-01
      相关资源
      最近更新 更多