鱼C论坛

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

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

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

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

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

x
源代码如下
  1. import logging
  2. from colorama import Fore,Style
  3. import sys


  4. # 获取对象
  5. def get_logger():
  6.     logger = logging.getLogger()
  7.     logger.setLevel(logging.DEBUG)

  8.     if not logger.handlers:
  9.         ch = logging.StreamHandler(sys.stdout)
  10.         ch.setLevel(logging.DEBUG)
  11.         formatter = logging.Formatter(
  12.             " %(message)s")
  13.         ch.setFormatter(formatter)
  14.         logger.addHandler(ch)
  15.     return logger

  16. #通过静态成员方法来调用
  17. class Log:

  18.     logger = get_logger()

  19.     @staticmethod
  20.     def debug(msg):
  21.         Log.logger.debug(Fore.WHITE + "[DEBUG]: " + str(msg) + Style.RESET_ALL)

  22.     @staticmethod
  23.     def info(msg):
  24.         Log.logger.info(Fore.GREEN + "[INFO]: " + str(msg) + Style.RESET_ALL)

  25.     @staticmethod
  26.     def warning(msg):
  27.         Log.logger.warning("\033[38;5;214m" + "[WARNING]: " + str(msg) + "\033[m")

  28.     @staticmethod
  29.     def error(msg):
  30.         Log.logger.error(Fore.RED + "[ERROR]: " + str(msg) + Style.RESET_ALL)

  31.     @staticmethod
  32.     def critical(msg):
  33.         Log.logger.critical(Fore.RED + "[CRITICAL]: " + str(msg) + Style.RESET_ALL)



  34. 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等支持颜色代码的终端上输出。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

  1. import logging
  2. from colorama import init, Fore,Style         # 加上 init
  3. import sys

  4. init(autoreset=True)         # 加上这行

  5. # 获取对象
  6. def get_logger():
  7.     logger = logging.getLogger()
  8.     logger.setLevel(logging.DEBUG)

  9.     if not logger.handlers:
  10.         ch = logging.StreamHandler(sys.stdout)
  11.         ch.setLevel(logging.DEBUG)
  12.         formatter = logging.Formatter(
  13.             " %(message)s")
  14.         ch.setFormatter(formatter)
  15.         logger.addHandler(ch)
  16.     return logger

  17. #通过静态成员方法来调用
  18. class Log:

  19.     logger = get_logger()

  20.     @staticmethod
  21.     def debug(msg):
  22.         Log.logger.debug(Fore.WHITE + "[DEBUG]: " + str(msg) + Style.RESET_ALL)

  23.     @staticmethod
  24.     def info(msg):
  25.         Log.logger.info(Fore.GREEN + "[INFO]: " + str(msg) + Style.RESET_ALL)

  26.     @staticmethod
  27.     def warning(msg):
  28.         Log.logger.warning("\033[38;5;214m" + "[WARNING]: " + str(msg) + "\033[m")

  29.     @staticmethod
  30.     def error(msg):
  31.         Log.logger.error(Fore.RED + "[ERROR]: " + str(msg) + Style.RESET_ALL)

  32.     @staticmethod
  33.     def critical(msg):
  34.         Log.logger.critical(Fore.RED + "[CRITICAL]: " + str(msg) + Style.RESET_ALL)



  35. Log.info('llllll')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

可以截个图吗?

https://imgtu.com/

把图放在图床,然后把链接发上来
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

https://imgtu.com/

https://imgtu.com/i/qj86PI
小甲鱼最新课程 -> https://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等支持颜色代码的终端上输出。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

哦,原来是这样啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-4-7 14:05:37 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-29 08:32

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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