溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

python中如何輸出結(jié)果刷新及進(jìn)度條

發(fā)布時(shí)間:2020-07-15 16:00:29 來(lái)源:億速云 閱讀:975 作者:小豬 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要為大家展示了python中如何輸出結(jié)果刷新及進(jìn)度條,內(nèi)容簡(jiǎn)而易懂,下面讓小編帶大家一起學(xué)習(xí)一下吧。

print函數(shù)

python輸出主要使用print函數(shù),print函數(shù)介紹:

print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)

*objects表示要打印的值,表示多個(gè)無(wú)名參數(shù)或需要打印的值;

sep=' ',對(duì)應(yīng)上面要打印的值中間間隔,默認(rèn)一個(gè)空格;

end='\n',傳入值打印完后的結(jié)束符號(hào),默認(rèn)為換行符,可以自行設(shè)置;

file=sys.stdout,設(shè)置打印輸出參數(shù),默認(rèn)打印到終端,也可設(shè)置打印保存到文件;

flush=False,是否刷新打印結(jié)果。

一行輸出結(jié)果并刷新

在一行中顯示輸出結(jié)果,每次刷新,其中'\r'表示回到當(dāng)前的開(kāi)頭,end=''表示結(jié)束符為空,這樣就可以每次更新結(jié)果

import time
for i in range(15):
  time.sleep(0.5) # 這里為了查看輸出變化,實(shí)際使用不需要sleep
  print('\r', i, end='')
  # print('\r', 15-i, end='') # 從兩位變一位會(huì)有問(wèn)題 

上面代碼有個(gè)問(wèn)題,當(dāng)輸出i從大到小,有位數(shù)變化時(shí),結(jié)果不正確,可用format格式化輸出,可解決問(wèn)題:

import time
for i in range(15):
  time.sleep(0.5)
  print('\r', "{:d}".format(15-i), end='')

模型訓(xùn)練中l(wèi)oss和acc的刷新輸出

我們?cè)谟?xùn)練機(jī)器學(xué)習(xí)和深度學(xué)習(xí)模型中,總會(huì)隔一段時(shí)間輸出損失函數(shù)和準(zhǔn)確率,每次都直接print輸出,終端會(huì)輸出很多信息,這里用單行輸出并刷新的方法來(lái)輸出這些信息,我們?cè)O(shè)置epochs和batch的數(shù)量,每次batch輸出刷新,一個(gè)epoch完后同時(shí)輸出train和test的結(jié)果。

import time

# 設(shè)置epochs和batch的數(shù)量
epochs = 5
n_batch = 15
# 這里是測(cè)試自己設(shè)置的loss和acc
train_loss = 1.2345
train_acc = 0.345678
test_loss = 1.1234
test_acc = 0.235467

for i in range(epochs):
  for j in range(n_batch):
    time.sleep(0.5)
    train_loss -= 0.001
    train_acc += 0.0001

    print("\rEpoch: {:d} batch: {:d} loss: {:.4f} acc: {:.4f} | {:.2%}"
       .format(i+1, j+1, train_loss, train_acc, (j+1)*1.0/n_batch), end='')
       
  test_loss -= 0.001
  test_acc += 0.0001
  
  print("\rEpoch: {:d}/{:d} train_loss: {:.4f} test_loss: {:.4f} train_acc: {:.4f} test_acc: {:.4f}"
   .format(i+1, 5, train_loss, test_loss, train_acc, test_acc), end='\n')

這里注意,print里"Epoch"前面有一個(gè)"\r",這個(gè)必須要有,同時(shí)里面循環(huán)end='',外面循環(huán)end='\n',最終打印結(jié)果如下:

python中如何輸出結(jié)果刷新及進(jìn)度條

tqdm顯示進(jìn)度條

首先安裝tqdm:pip install tqdm

簡(jiǎn)單使用,讀取整數(shù),直接在tqdm中傳入一個(gè)list, 如果直接給定的是一個(gè)整數(shù),可以直接用trange

import time
from tqdm import tqdm, trange

for i in tqdm(range(100)):
  time.sleep(0.05)
  # do something

# for i in trange(100):
#   time.sleep(0.05)
#   # do something

顯示結(jié)果如下,顯示有百分比,以及當(dāng)前處理到多少個(gè)

python中如何輸出結(jié)果刷新及進(jìn)度條

tdqm輸入的list可以是字符串,也可以對(duì)輸出進(jìn)度條加一些描述

import time
from tqdm import tqdm
pbar = tqdm(["a", "b", "c", "d", "e"])
for char in pbar:
  time.sleep(0.8)
  pbar.set_description("Processing %s" % char)
  # pbar.set_description("Processing {0}".format(char))

python中如何輸出結(jié)果刷新及進(jìn)度條

以上就是關(guān)于python中如何輸出結(jié)果刷新及進(jìn)度條的內(nèi)容,如果你們有學(xué)習(xí)到知識(shí)或者技能,可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI