我无法在GitHub或docs上找到它,但是我想知道是否有一种集成的方法(首选)或解决方法来显示一次迭代的平均时间分钟而不是秒。
具体来说,tqdm显示类似1283.31s/it
的内容,但是如果每次迭代都花费大量时间(例如数分钟或数小时),则显示类似21m/it
的内容将更有帮助。
答案 0 :(得分:1)
我们可以通过使用指令partially described in the manual向bar_format
的自定义实例添加自定义tqdm
参数来做到这一点:
class TqdmExtraFormat(tqdm):
"""Provides a `minutes per iteration` format parameter"""
@property
def format_dict(self):
d = super(TqdmExtraFormat, self).format_dict
rate_min = '{:.2f}'.format(1/d["rate"] / 60) if d["rate"] else '?'
d.update(rate_min=(rate_min + ' min/' + d['unit']))
return d
我们在这里所做的是使用自定义版本覆盖format_dict
,该自定义版本添加了可以在bar_format
参数中使用的新统计信息。 d
是现有的format_dict
,因此我们可以使用它来获取{rate}
的值,将其转换为每次迭代的时间(1 /速率),除以60,然后将其格式化为小数点后2位。然后,我们使用新的统计信息更新d
-我们甚至可以使用字符串连接来添加一些格式。请注意,在任何迭代完成之前,{rate}
是None
,这意味着除非您进行if d["rate"]
检查,否则这将产生错误。
完成此操作后,如果您使用bar_format
的自定义实例,我们可以在tqdm
参数字符串中将此统计信息与Parameters中列出的参数一起使用:
b='{l_bar}{bar}| {n_fmt}/{total_fmt} [{elapsed}<{remaining}, {rate_min}{postfix}]'
for i in TqdmExtraFormat(range(2), unit_scale = 60, bar_format=b):
time.sleep(6)