gpt4 book ai didi

python - 记录 : print message only once

转载 作者:太空狗 更新时间:2023-10-29 20:27:21 25 4
gpt4 key购买 nike

我在 python 3 中使用 logging 模块,并希望特定的警告消息只显示一次。问题是检查在循环内:

def canned_example():
logger.warning("This function hasn't been created yet")


for i in range(10):
canned_example()

是否有一个标志可以在日志模块中设置,表示这个特定的警告只显示一次?另一种方法是记录不同的标志,但我希望尽可能保持简单。

更新:Amir Yazdanbakhsh 在评论中发布了一个答案,允许我们对所有消息执行此操作。理想情况下,我想要一些每条消息的标志:

def canned_example():
logger.warning("This function hasn't been created yet", norepeat=True)


for i in range(10):
canned_example()

最佳答案

定义一个过滤器来跟踪记录的内容,并在循环期间将其附加到您的记录器。此示例将记住它看到的每条消息,并且只允许记录第一次出现的消息。

class DuplicateFilter(object):
def __init__(self):
self.msgs = set()

def filter(self, record):
rv = record.msg not in self.msgs
self.msgs.add(record.msg)
return rv

dup_filter = DuplicateFilter()
logger.addFilter(dup_filter)
for i in range(10):
canned_example()
logger.removeFilter(dup_filter)

关于python - 记录 : print message only once,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31953272/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com