鱼C论坛

 找回密码
 立即注册
查看: 1597|回复: 7

[已解决]logging字体颜色问题

[复制链接]
发表于 2022-4-2 11:48:58 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
源代码如下
import logging
from colorama import Fore,Style
import sys
 
 
# 获取对象
def get_logger():
    logger = logging.getLogger()
    logger.setLevel(logging.DEBUG)
 
    if not logger.handlers:
        ch = logging.StreamHandler(sys.stdout)
        ch.setLevel(logging.DEBUG)
        formatter = logging.Formatter(
            " %(message)s")
        ch.setFormatter(formatter)
        logger.addHandler(ch)
    return logger
 
#通过静态成员方法来调用
class Log:
 
    logger = get_logger()
 
    @staticmethod
    def debug(msg):
        Log.logger.debug(Fore.WHITE + "[DEBUG]: " + str(msg) + Style.RESET_ALL)
 
    @staticmethod
    def info(msg):
        Log.logger.info(Fore.GREEN + "[INFO]: " + str(msg) + Style.RESET_ALL)
 
    @staticmethod
    def warning(msg):
        Log.logger.warning("\033[38;5;214m" + "[WARNING]: " + str(msg) + "\033[m")
 
    @staticmethod
    def error(msg):
        Log.logger.error(Fore.RED + "[ERROR]: " + str(msg) + Style.RESET_ALL)
 
    @staticmethod
    def critical(msg):
        Log.logger.critical(Fore.RED + "[CRITICAL]: " + str(msg) + Style.RESET_ALL)



Log.info('llllll')



为什么在控制台输出的文字并没有变成绿色,反而前后还有口[32m 和 口[0m??
输出结果为:
[INFO]: llllll
最佳答案
2022-4-6 17:59:07
2022@lif 发表于 2022-4-6 13:29
https://imgtu.com/i/qj86PI

你要知道IDLE不支持ANSI颜色代码的,想要显示颜色你得在cmd或者powershell等支持颜色代码的终端上输出。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-4-2 11:53:05 | 显示全部楼层
在 windows 中得用 init 初始化一下
import logging
from colorama import init, Fore,Style         # 加上 init
import sys

init(autoreset=True)         # 加上这行

# 获取对象
def get_logger():
    logger = logging.getLogger()
    logger.setLevel(logging.DEBUG)
 
    if not logger.handlers:
        ch = logging.StreamHandler(sys.stdout)
        ch.setLevel(logging.DEBUG)
        formatter = logging.Formatter(
            " %(message)s")
        ch.setFormatter(formatter)
        logger.addHandler(ch)
    return logger
 
#通过静态成员方法来调用
class Log:
 
    logger = get_logger()
 
    @staticmethod
    def debug(msg):
        Log.logger.debug(Fore.WHITE + "[DEBUG]: " + str(msg) + Style.RESET_ALL)
 
    @staticmethod
    def info(msg):
        Log.logger.info(Fore.GREEN + "[INFO]: " + str(msg) + Style.RESET_ALL)
 
    @staticmethod
    def warning(msg):
        Log.logger.warning("\033[38;5;214m" + "[WARNING]: " + str(msg) + "\033[m")
 
    @staticmethod
    def error(msg):
        Log.logger.error(Fore.RED + "[ERROR]: " + str(msg) + Style.RESET_ALL)
 
    @staticmethod
    def critical(msg):
        Log.logger.critical(Fore.RED + "[CRITICAL]: " + str(msg) + Style.RESET_ALL)



Log.info('llllll')
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-2 13:25:17 | 显示全部楼层
isdkz 发表于 2022-4-2 11:53
在 windows 中得用 init 初始化一下

出来的结果还是这样子的:
[INFO]: llllll

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-2 13:40:59 | 显示全部楼层
2022@lif 发表于 2022-4-2 13:25
出来的结果还是这样子的:
[32m: llllll [0m
[0m

可以截个图吗?

https://imgtu.com/

把图放在图床,然后把链接发上来
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-6 13:29:04 | 显示全部楼层
isdkz 发表于 2022-4-2 13:40
可以截个图吗?

https://imgtu.com/

https://imgtu.com/i/qj86PI
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-6 17:59:07 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
2022@lif 发表于 2022-4-6 13:29
https://imgtu.com/i/qj86PI

你要知道IDLE不支持ANSI颜色代码的,想要显示颜色你得在cmd或者powershell等支持颜色代码的终端上输出。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-4-7 08:57:35 | 显示全部楼层
hrpzcf 发表于 2022-4-6 17:59
你要知道IDLE不支持ANSI颜色代码的,想要显示颜色你得在cmd或者powershell等支持颜色代码的终端上输出。

哦,原来是这样啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 14:05:37 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-11 19:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表