- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在做一些并行处理,如下:
with mp.Pool(8) as tmpPool:
results = tmpPool.starmap(my_function, inputs)
输入看起来像: [(1,0.2312),(5,0.52) ...]即 int 和 float 的元组。
代码运行良好,但我似乎无法将它包裹在加载栏 (tqdm) 周围,例如可以使用 imap 方法完成,如下所示:
tqdm.tqdm(mp.imap(some_function,some_inputs))
这也可以用于星图吗?
谢谢!
最佳答案
使用 starmap()
是不可能的,但是可以通过添加 Pool.istarmap()
的补丁来实现。它基于 imap()
的代码。您所要做的就是创建 istarmap.py
文件并导入模块以应用补丁,然后再进行常规的多处理导入。
python <3.8
# istarmap.py for Python <3.8
import multiprocessing.pool as mpp
def istarmap(self, func, iterable, chunksize=1):
"""starmap-version of imap
"""
if self._state != mpp.RUN:
raise ValueError("Pool not running")
if chunksize < 1:
raise ValueError(
"Chunksize must be 1+, not {0:n}".format(
chunksize))
task_batches = mpp.Pool._get_tasks(func, iterable, chunksize)
result = mpp.IMapIterator(self._cache)
self._taskqueue.put(
(
self._guarded_task_generation(result._job,
mpp.starmapstar,
task_batches),
result._set_length
))
return (item for chunk in result for item in chunk)
mpp.Pool.istarmap = istarmap
Python 3.8+
# istarmap.py for Python 3.8+
import multiprocessing.pool as mpp
def istarmap(self, func, iterable, chunksize=1):
"""starmap-version of imap
"""
self._check_running()
if chunksize < 1:
raise ValueError(
"Chunksize must be 1+, not {0:n}".format(
chunksize))
task_batches = mpp.Pool._get_tasks(func, iterable, chunksize)
result = mpp.IMapIterator(self)
self._taskqueue.put(
(
self._guarded_task_generation(result._job,
mpp.starmapstar,
task_batches),
result._set_length
))
return (item for chunk in result for item in chunk)
mpp.Pool.istarmap = istarmap
然后在你的脚本中:
import istarmap # import to apply patch
from multiprocessing import Pool
import tqdm
def foo(a, b):
for _ in range(int(50e6)):
pass
return a, b
if __name__ == '__main__':
with Pool(4) as pool:
iterable = [(i, 'x') for i in range(10)]
for _ in tqdm.tqdm(pool.istarmap(foo, iterable),
total=len(iterable)):
pass
关于python - 星图与 tqdm 结合?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57354700/
这个问题已经有答案了: 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 文件读入内存,因此我
我是一名优秀的程序员,十分优秀!