python写日志到文件_Python日志文件没有正确地写入日志消息,只有格式

我一夜之间运行了一个Python脚本,发现日志文件只是我指定的消息格式的重复行,而不是实际的消息。在

main

模块中,我创建了如下记录器:

from datetime import datetime

import logging

import os

def main():

msg_format = '[%(asctime)s - %(levelname)s - %(filename)s: %(lineno)d (%(funcName)s)] %(message)s'

logging.basicConfig(format=msg_format, level=logging.INFO)

logger = logging.getLogger()

logger.setLevel(level=logging.INFO)

timestamp = datetime.now().strftime(format='%Y%m%d-%H%M')

log_filename = '_'.join(['log', run_type, timestamp]) + '.txt'

save_pathname = '_'.join([run_type, datetime.now().strftime(format='%Y%m%d')])

save_path = os.path.join(save_path, save_pathname)

if not os.path.exists(save_path):

os.mkdir(path=save_path)

log_file = os.path.join(save_path, log_filename)

file_handler = logging.FileHandler(filename=log_file)

file_handler.setLevel(level=logging.INFO)

file_handler.setFormatter(fmt=msg_format)

logger.addHandler(hdlr=file_handler)

.

.

.

logger.info(msg='something')

整个模块中的语句。当我打开日志文件时,我看到的只是:

[%(asctime)s - %(levelname)s - %(filename)s: %(lineno)d (%(funcName)s)] %(message)s

[%(asctime)s - %(levelname)s - %(filename)s: %(lineno)d (%(funcName)s)] %(message)s

[%(asctime)s - %(levelname)s - %(filename)s: %(lineno)d (%(funcName)s)] %(message)s

[%(asctime)s - %(levelname)s - %(filename)s: %(lineno)d (%(funcName)s)] %(message)s

.

.

.

日志初始化的哪个部分出错了?我应该显式地设置吗

filemode='w'

logging.basicConfig

? 谢谢。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值