求助 Python cmd 内中文变问号 求各位大佬看一眼

2019-12-03 11:39:54 +08:00
 hahahalololo

中文 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 添加指定编码,但失败了,网上也没到。

求各位大佬看下。

还有,这里不能发图片吗?找了半天没发现添加图片的选项。

907 次点击
所在节点    问与答
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/625441

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX