- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个简单的问题:如何将内置 Python 记录器的 print
函数更改为 tqdm.write
,以便记录消息不会干扰 tqdm 的进度条?谢谢!
最佳答案
您需要一个自定义日志处理程序:
import logging
import tqdm
class TqdmLoggingHandler(logging.Handler):
def __init__(self, level=logging.NOTSET):
super().__init__(level)
def emit(self, record):
try:
msg = self.format(record)
tqdm.tqdm.write(msg)
self.flush()
except Exception:
self.handleError(record)
然后将其添加到日志记录链中:
import time
log = logging.getLogger(__name__)
log.setLevel(logging.INFO)
log.addHandler(TqdmLoggingHandler())
for i in tqdm.tqdm(range(100)):
if i == 50:
log.info("Half-way there!")
time.sleep(0.1)
编辑:修复了调用 super TqdmLoggingHandler 的 init 方法时的错误,勤奋的读者@BlaineRogers 在评论中指出了这一错误。 (如果有人想进一步了解 Python 的这个阴暗区域,我推荐 https://fuhm.net/super-harmful/ )
关于python - 将日志记录 "print"函数更改为 "tqdm.write",以便日志记录不会干扰进度条,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38543506/
这个问题已经有答案了: What can I do about "ImportError: Cannot import name X" or "AttributeError: ... (most li
我正在使用Python3.6运行以下像素递归神经网络(RNN)代码。但是,出现了一个错误:。有谁知道怎么解这个题吗?
我正在研究 Pytorchlightning,tqdm 的进度条有很多问题,它不断地从短到长来回调整大小,让阅读日志文本变得非常不愉快,我意识到进度条并不是真正必要的,我只想保留当前epoch、当前b
我有一组进度条,我使用 tqdm.write 在它们运行时在它们上面打印日志消息。出于审美原因,我想用空行或类似重复的“=”在视觉上将日志消息与进度条分开,例如: Log message 1
我正在尝试使用 Python 中可用的 tqdm 模块打印优化算法的进度状态,但是,每次我尝试更新它时,它都会在新行中打印进度,有没有办法我只能更新最初正在实例化的原始 tqdm 条?我的代码如下,它
我想在我的脚本中使用 tqdm 但不要求其他人使用它,如果他们还没有安装的话。 我发现了这个: try: import tqdm except ImportError: tqdm =
我在递归目录树时使用 tqdm。我不知道我将使用的路径数,而且我不想在我做工作之前建立该列表只是为了获得准确的总数,我宁愿让它更新进度条为它继续。 我发现我可以很好地使用 'reset(total=n
在从 SQL 数据库读取大型关系到 pandas 数据帧时,最好有一个进度条,因为元组的数量是静态已知的,并且可以估计 I/O 率。它看起来像 tqdm模块有一个函数tqdm_pandas它将报告列上
我正在尝试使用 tqdm 报告从三个链接下载每个文件的进度,我想使用多线程从每个链接同时下载同时更新进度条。 但是当我执行我的脚本时,有多行进度条似乎线程正在同时更新 tqdm 进度条。 我在问我应该
我有一个使用 tqdm 的 python 包进度条。但是,我不希望这成为我的包的用户的硬依赖。如果未安装 tqdm,是否有一些简单的嵌入式解决方案可以轻松充当备用解决方案? 我正在使用 tqdm.tq
我正在尝试编写一个使用多个线程来完成其工作的程序,因此我想通过多个进度条(每个线程一个)来显示进度。我的代码看起来很像这样 import threading def my_function(posit
这个问题在这里已经有了答案: Redirect print command in python script through tqdm.write() (5 个答案) 关闭 5 年前。 我有以下 P
我正在使用 tqdm 库,它没有给我进度条,而是给我如下所示的输出,它只是告诉我迭代: 251it [01:44, 2.39it/s] 知道为什么代码会这样做吗?我想这可能是因为我给它传递了一个发电机
我正在使用 python 开发一个小型命令行游戏,我正在使用 tqdm 模块显示进度条。我使用 msvcrt 模块监听用户输入以中断进度。一旦中断,用户可以通过在命令行提示符中输入“restart”来
我正在循环一个我知道长度的大文件,但是由于它太大而无法放入内存,所以我正在懒惰地处理。我希望能够使用 tqdm 来跟踪我在文件中的进度,但是由于它无法从我正在使用的生成器中获取示例总数,因此它唯一显示
我想在每个进程中使用 4 个 python 进程和 tqdm 进度条: 66%|███████████████████████████▌ | 80/122 [00:44<0
我有一个 tqdm 进度条。我在代码的某些部分使用 set_postfix_str 方法设置后缀字符串。在另一部分,我需要附加到这个字符串。这是一个 MWE。 import numpy as np f
我正在尝试创建一个进度条,只要异步任务完成,它就会更新。 我有以下代码 scan_results = [] tasks = [self.run_scan(i) for i in input_paths
当我使用 bar_format 选项添加颜色时,我不确定为什么我的 TQDM 进度条分成多行。它似乎也与迭代次数有关,因为当我运行相同的代码时只有 10 次迭代而不是 1389 次迭代时它不会 spl
我有多个并行处理的大量 csv 文件。我希望每个文件都有一个进度条。 但是,虽然我显示了 5 个条,但只有最后一个正在更新 - 似乎所有进程都会同时更新。由于我无法将整个 csv 文件读入内存,因此我
我是一名优秀的程序员,十分优秀!