首页 > 编程问答 >如何从命令行设置日志记录级别

如何从命令行设置日志记录级别

时间:2024-07-22 06:18:29浏览次数:16  
标签:python logging argparse

我使用 argparse 从命令行获取日志记录级别,然后将其作为logging.basicConfig的输入传递。然而,我试图实现这一点的方式不起作用。有什么建议吗?

期望的行为,来自命令行:

python main.py -log=DEBUG

期望的输出

DEBUG:__main__: Debug is working

代码

import logging
import argparse

parser = argparse.ArgumentParser()
parser.add_argument("-log", "--log", nargs='+', help="Provide logging level. Example --log debug'")

log_level = parser.parse_args().log
log_level = 'logging.'+log_level[0]
print(log_level)
logging.basicConfig(level=log_level)
logger = logging.getLogger(__name__) 
logger.debug(' Debug is working')

在代码中遇到的问题是将日志记录级别作为字符串“logging.DEBUG”传递,而不是实际的日志记录级别。应该使用 logging 模块中的常量,例如 logging.DEBUG

以下是代码的更正版本:

import logging
import argparse

parser = argparse.ArgumentParser()
parser.add_argument("-log", "--log", help="提供日志记录级别。例如,--log DEBUG")

args = parser.parse_args()
log_level = getattr(logging, args.log.upper(), None)

if not isinstance(log_level, int):
    raise ValueError('无效的日志记录级别: %s' % args.log)

logging.basicConfig(level=log_level)
logger = logging.getLogger(__name__)
logger.debug('调试正常')

说明:

  1. 获取日志记录级别:

    • 我们使用 args.log.upper() 获取提供的日志记录级别字符串并将其转换为大写字母,以支持大小写不敏感的输入(例如,“debug”、“DEBUG”)。
    • 我们使用 getattr(logging, args.log.upper(), None) 安全地从 logging 模块中获取相应的日志记录级别。如果提供的日志记录级别无效,这将返回 None
  2. 验证日志记录级别:

    • 我们检查获得的 log_level 是否是 int 类型的实例。所有有效的日志记录级别(例如, logging.DEBUG logging.INFO 等)都是整数。如果它不是整数,则会引发 ValueError ,指示无效的日志记录级别。
  3. 设置日志记录级别:

    • 如果日志记录级别有效,我们使用 logging.basicConfig(level=log_level) 将根记录器的日志记录级别设置为提供的级别。

通过这些更改,的代码现在应该能够从命令行参数中正确解析和设置日志记录级别。

标签:python,logging,argparse
From: 57192387

相关文章

  • 具有未定义嵌套列表深度的嵌套列表的Python注释类型
    [[1,2,3],3,[2,4],5]的类型是list[list[int]|int]但是,如果嵌套列表具有未定义的深度,例如[[[1,2]],2,[1,[3,[3]]]],3,[2,[2]]],那么它会具有什么类型?可以使用递归类型提示来表示任意深度嵌套的列表:fromtypingimportList,Union......
  • 在Spyder(Python 3.6)中导入cv2时出现导入错误
    我已经在Windows操作系统中安装了opencv3.0.0。我已运行该应用程序并已成功将其安装在C:\驱动器中,并且还将cv2.pyd文件复制到C:\Python27\Lib\site-packages中,正如我在几个教程视频中看到的那样在我的Python2.7.5Shell中,即当我键入>>>i......
  • Python + VS Code 调试器:可视化我的程序当前正在执行的源代码中的位置?
    当我使用VSCodePython调试器时:我可以执行我的程序,以便编辑器将我逐行带到源代码中的任何位置(跳转到相关文件/如果尚未打开则将其打开)目前的执行情况是?是的,VSCode的Python调试器可以让你逐行执行代码,并实时显示当前执行的位置。以下是操作方法:1.设置断点:......
  • 如何立即取消使用 Ollama Python 库生成答案的 Asyncio 任务?
    我正在使用Ollama通过OllamaPythonAPI从大型语言模型(LLM)生成答案。我想通过单击停止按钮取消响应生成。问题在于,只有当响应生成已经开始打印时,任务取消才会起作用。如果任务仍在处理并准备打印,则取消不起作用,并且无论如何都会打印响应。更具体地说,即使单击按钮后,此函数......
  • 使用 np.array 索引过滤 Python 列表
    谁能向我解释一下列表self.data如何使用numpy索引数组selec_idx进行索引/过滤?完整的课程可在https://github.com/kaidic/LDAM-DRW/blob/master/imbalance_cifar.pydefgen_imbalanced_data(self,img_num_per_cls):new_data=[]n......
  • 尝试在cmd(python)中安装turtle
    当我在cmd中编写pipinstallturtle后,这条消息出现在我面前。有人知道该怎么办吗?C:\>pipinstallturtleCollectingturtleUsingcachedturtle-0.0.2.tar.gz(11kB)ERROR:Commanderroredoutwithexitstatus1:command:'C:\Users\Bruger\App......
  • Python + Polars:如何有效地“fill_null”仅 DataFrame 的某些列?
    例如,假设我只想fill_null(strategy="zero")DataFrame的数字列。我当前的策略是这样做:final_df=df.select(cs.exclude(cs.numeric()))final_df.with_columns(df.select(cs.numeric()).fill_null(strategy="zero"))是否有替代的、更惯用或更有效的方法来实现我......
  • 如何找到 Windows 上 Python 的安装位置?
    我想找出我的Python在Windows上的安装路径。例如:C:\Python25如何找到Python的安装位置?在Windows上查找Python安装位置的方法有很多种:1.使用where命令(推荐方法):打开命令提示符(cmd)。输入以下命令并按回车键:wherepython......
  • Python Pandas:如何解析没有行结尾的 CSV
    如何解析没有行结尾的CSV文件?示例数据sep=;Id;Date;1;1980-02-29;2;1980-03-10;3;;可以使用lineterminator参数指定行终止符来解析没有行尾的CSV文件。在这种情况下,你可以将lineterminator设置为一个空字符串('')。以下是使用......
  • Python 中的 azure.ai.translation.document - 无法使用当前权限访问源文档位置
    我在使用Python中的azure.ai.translation.document库时遇到问题。我已经在Azure中设置了翻译服务以及带有两个容器的Blob存储。我已使用“用户委托密钥”创建了SAS连接。一种用于源(读取/列表),一种用于目标(写入/列表)。例如我尝试运行Python程序,但源b......