詳細(xì)介紹Python進(jìn)度條tqdm的使用
前言
有時(shí)候在使用Python處理比較耗時(shí)操作的時(shí)候,為了便于觀察處理進(jìn)度,這時(shí)候就需要通過進(jìn)度條將處理情況進(jìn)行可視化展示,以便我們能夠及時(shí)了解情況。這對(duì)于第三方庫(kù)非常豐富的Python來(lái)說,想要實(shí)現(xiàn)這一功能并不是什么難事。
tqdm
就能非常完美的支持和解決這些問題,可以實(shí)時(shí)輸出處理進(jìn)度而且占用的CPU資源非常少
,支持windows
、Linux
、mac
等系統(tǒng),支持循環(huán)處理
、多進(jìn)程
、遞歸處理
、還可以結(jié)合linux
的命令來(lái)查看處理情況,等進(jìn)度展示。
大家先看看tqdm的進(jìn)度條效果
安裝
github地址:https://github.com/tqdm/tqdm
想要安裝tqdm
也是非常簡(jiǎn)單的,通過pip或conda就可以安裝,而且不需要安裝其他的依賴庫(kù)
pip安裝
pip install tqdm
conda安裝
conda install -c conda-forge tqdm
迭代對(duì)象處理
對(duì)于可以迭代的對(duì)象
都可以使用下面這種方式,來(lái)實(shí)現(xiàn)可視化進(jìn)度,非常方便
from tqdm import tqdm import time for i in tqdm(range(100)): time.sleep(0.1) pass
在使用tqdm
的時(shí)候,可以將tqdm(range(100))
替換為trange(100)
代碼如下
from tqdm import tqdm,trange import time for i in trange(100): time.sleep(0.1) pass
觀察處理的數(shù)據(jù)
通過tqdm
提供的set_description
方法可以實(shí)時(shí)查看每次處理的數(shù)據(jù)
from tqdm import tqdm import time pbar = tqdm(["a","b","c","d"]) for c in pbar: time.sleep(1) pbar.set_description("Processing %s"%c)
手動(dòng)設(shè)置處理的進(jìn)度
通過update
方法可以控制每次進(jìn)度條更新的進(jìn)度
from tqdm import tqdm import time #total參數(shù)設(shè)置進(jìn)度條的總長(zhǎng)度 with tqdm(total=100) as pbar: for i in range(100): time.sleep(0.05) #每次更新進(jìn)度條的長(zhǎng)度 pbar.update(1)
除了使用with
之外,還可以使用另外一種方法實(shí)現(xiàn)上面的效果
from tqdm import tqdm import time #total參數(shù)設(shè)置進(jìn)度條的總長(zhǎng)度 pbar = tqdm(total=100) for i in range(100): time.sleep(0.05) #每次更新進(jìn)度條的長(zhǎng)度 pbar.update(1) #關(guān)閉占用的資源 pbar.close()
linux命令展示進(jìn)度條
不使用tqdm
$ time find . -name '*.py' -type f -exec cat \{} \; | wc -l 857365 real 0m3.458s user 0m0.274s sys 0m3.325s
使用tqdm
$ time find . -name '*.py' -type f -exec cat \{} \; | tqdm | wc -l 857366it [00:03, 246471.31it/s] 857365 real 0m3.585s user 0m0.862s sys 0m3.358s
指定tqdm的參數(shù)控制進(jìn)度條
$ find . -name '*.py' -type f -exec cat \{} \; | tqdm --unit loc --unit_scale --total 857366 >> /dev/null 100%|███████████████████████████████████| 857K/857K [00:04<00:00, 246Kloc/s]
$ 7z a -bd -r backup.7z docs/ | grep Compressing | tqdm --total $(find docs/ -type f | wc -l) --unit files >> backup.log 100%|███████████████████████████████▉| 8014/8014 [01:37<00:00, 82.29files/s]
自定義進(jìn)度條顯示信息
通過set_description
和set_postfix
方法設(shè)置進(jìn)度條顯示信息
from tqdm import trange from random import random,randint import time with trange(100) as t: for i in t: #設(shè)置進(jìn)度條左邊顯示的信息 t.set_description("GEN %i"%i) #設(shè)置進(jìn)度條右邊顯示的信息 t.set_postfix(loss=random(),gen=randint(1,999),str="h",lst=[1,2]) time.sleep(0.1)
from tqdm import tqdm import time with tqdm(total=10,bar_format="{postfix[0]}{postfix[1][value]:>9.3g}", postfix=["Batch",dict(value=0)]) as t: for i in range(10): time.sleep(0.05) t.postfix[1]["value"] = i / 2 t.update()
多層循環(huán)進(jìn)度條
通過tqdm
也可以很簡(jiǎn)單的實(shí)現(xiàn)嵌套循環(huán)進(jìn)度條的展示
from tqdm import tqdm import time for i in tqdm(range(20), ascii=True,desc="1st loop"): for j in tqdm(range(10), ascii=True,desc="2nd loop"): time.sleep(0.01)
在pycharm
中執(zhí)行以上代碼的時(shí)候,會(huì)出現(xiàn)進(jìn)度條位置錯(cuò)亂,目前官方并沒有給出好的解決方案,這是由于pycharm不支持某些字符導(dǎo)致的,不過可以將上面的代碼保存為腳本然后在命令行中執(zhí)行,效果如下
多進(jìn)程進(jìn)度條
在使用多進(jìn)程處理任務(wù)的時(shí)候,通過tqdm可以實(shí)時(shí)查看每一個(gè)進(jìn)程任務(wù)的處理情況
from time import sleep from tqdm import trange, tqdm from multiprocessing import Pool, freeze_support, RLock L = list(range(9)) def progresser(n): interval = 0.001 / (n + 2) total = 5000 text = "#{}, est. {:<04.2}s".format(n, interval * total) for i in trange(total, desc=text, position=n,ascii=True): sleep(interval) if __name__ == '__main__': freeze_support() # for Windows support p = Pool(len(L), # again, for Windows support initializer=tqdm.set_lock, initargs=(RLock(),)) p.map(progresser, L) print("\n" * (len(L) - 2))
pandas中使用tqdm
import pandas as pd import numpy as np from tqdm import tqdm df = pd.DataFrame(np.random.randint(0, 100, (100000, 6))) tqdm.pandas(desc="my bar!") df.progress_apply(lambda x: x**2)
遞歸使用進(jìn)度條
from tqdm import tqdm import os.path def find_files_recursively(path, show_progress=True): files = [] # total=1 assumes `path` is a file t = tqdm(total=1, unit="file", disable=not show_progress) if not os.path.exists(path): raise IOError("Cannot find:" + path) def append_found_file(f): files.append(f) t.update() def list_found_dir(path): """returns os.listdir(path) assuming os.path.isdir(path)""" try: listing = os.listdir(path) except: return [] # subtract 1 since a "file" we found was actually this directory t.total += len(listing) - 1 # fancy way to give info without forcing a refresh t.set_postfix(dir=path[-10:], refresh=False) t.update(0) # may trigger a refresh return listing def recursively_search(path): if os.path.isdir(path): for f in list_found_dir(path): recursively_search(os.path.join(path, f)) else: append_found_file(path) recursively_search(path) t.set_postfix(dir=path) t.close() return files find_files_recursively("E:/")
注意
在使用tqdm
顯示進(jìn)度條的時(shí)候,如果代碼中存在print
可能會(huì)導(dǎo)致輸出多行進(jìn)度條,此時(shí)可以將print
語(yǔ)句改為tqdm.write
,代碼如下
for i in tqdm(range(10),ascii=True): tqdm.write("come on") time.sleep(0.1)
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python實(shí)現(xiàn)指定區(qū)域桌面變化監(jiān)控并報(bào)警
在這篇博客中,我們將使用Python編程語(yǔ)言和一些常用的庫(kù)來(lái)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的區(qū)域監(jiān)控和變化報(bào)警系統(tǒng),文中有詳細(xì)的代碼示例供大家參考,需要的朋友可以參考下2023-07-07numpy ndarray 取出滿足特定條件的某些行實(shí)例
今天小編就為大家分享一篇numpy ndarray 取出滿足特定條件的某些行實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2019-12-12Python基礎(chǔ)必備之語(yǔ)法結(jié)構(gòu)詳解
Python語(yǔ)法定義了用于在 Python 編程中創(chuàng)建句子的所有規(guī)則集。如果想更深入地研究 Python 詞法結(jié)構(gòu),需要了解構(gòu)成語(yǔ)句的句法元素,即構(gòu)成 Python 程序的基本單元,涵蓋控制結(jié)構(gòu),在不同代碼組之間引導(dǎo)程序流的構(gòu)造,快跟隨小編一起學(xué)習(xí)一下吧2022-04-04Python標(biāo)準(zhǔn)庫(kù)datetime之datetime模塊用法分析詳解
這篇文章主要介紹了Python標(biāo)準(zhǔn)庫(kù)datetime之datetime模塊用法分析詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07Python實(shí)現(xiàn)識(shí)別圖片為文字的示例代碼
這篇文章主要為大家詳細(xì)介紹了Python如何不調(diào)用三方收費(fèi)接口,照樣實(shí)現(xiàn)識(shí)別圖片為文字的功能。文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-08-08python在命令行下使用google翻譯(帶語(yǔ)音)
這篇文章主要介紹了使用google翻譯服務(wù)獲得翻譯和語(yǔ)音的示例,大家參考使用吧2014-01-01Python實(shí)現(xiàn)將json文件生成C語(yǔ)言的結(jié)構(gòu)體的腳本分享
這篇文章主要為大家詳細(xì)介紹了Python如何實(shí)現(xiàn)將json文件生成C語(yǔ)言的結(jié)構(gòu)體,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-09-09Python實(shí)現(xiàn)的密碼強(qiáng)度檢測(cè)器示例
這篇文章主要介紹了Python實(shí)現(xiàn)的密碼強(qiáng)度檢測(cè)器,結(jié)合實(shí)例形式分析了Python密碼強(qiáng)度檢測(cè)的原理與實(shí)現(xiàn)方法,涉及Python字符串運(yùn)算與轉(zhuǎn)換、判斷等相關(guān)操作技巧,需要的朋友可以參考下2017-08-08wxPython:python首選的GUI庫(kù)實(shí)例分享
wxPython是Python語(yǔ)言的一套優(yōu)秀的GUI圖形庫(kù)。允許Python程序員很方便的創(chuàng)建完整的、功能鍵全的GUI用戶界面。 wxPython是作為優(yōu)秀的跨平臺(tái)GUI庫(kù)wxWidgets的Python封裝和Python模塊的方式提供給用戶的2019-10-10