中文 windows 操作系统中没问题,但在英文操作系统 windows,logging 日志文件里面中文是正常的,但控制台上输出的是问号
下面为代码:
import logging
import os
import time
def set_log(now_path, log_folder_name, log_name): # 配置日志相关
try:
os.makedirs('{}/{}'.format(now_path, log_folder_name))
except IOError:
pass
logger = logging.getLogger()
logger.setLevel('INFO')
basic_format = '%(asctime)s %(levelname)s:%(message)s'
date_format = '%Y-%m-%d %H:%M:%S'
formatter = logging.Formatter(basic_format, date_format)
console_handler = logging.StreamHandler() # 输出到控制台的 handler
console_handler.setFormatter(formatter)
console_handler.setLevel('INFO') # 也可以不设置,不设置就默认用 logger 的 level
file_handler = logging.FileHandler(filename='{}/{}/{}'.format(
now_path,
log_folder_name,
log_name,
),
encoding='utf8'
) # 输出到文件的 handler
file_handler.setFormatter(formatter)
logger.addHandler(console_handler)
logger.addHandler(file_handler)
logging.info('set log success')
logging.info('成功')
set_log('./', 'MyLog', '{}.log'.format(time.strftime('%Y-%m-%d %H-%M-%M')))
运行后的结果是日志文件内中文没有问题,但 cmd 输出的中文变问号。我尝试给输出到控制台的 handler 添加指定编码,但失败了,网上也没到。
求各位大佬看下。
还有,这里不能发图片吗?找了半天没发现添加图片的选项。