關(guān)于Python錯誤重試方法總結(jié)
前言
Tenacity是一個 Apache 2.0授權(quán)的通用重試庫,用 Python 編寫,用于簡化向幾乎所有內(nèi)容添加重試行為的任務(wù)。它起源于一個重新嘗試的分支,可惜這個分支已經(jīng)不復(fù)存在了。
使用Tenacity可以用來進行測試用例的重跑,爬蟲腳本的重跑,以及搶票的失敗重搶等等。。??梢允褂玫膱鼍耙彩潜容^多。
使用
首先安裝Tenacity
pip install Tenacity
無限重試
第一個重試案例,因為一直是拋出異常錯誤,所以無限進行重試執(zhí)行
from tenacity import retry
@retry()
def test_retry():
print('失敗重試中')
raise Exception
test_retry()

成功則停止
我們來優(yōu)化成功一次后程序則終止,否則繼續(xù)重試。
from tenacity import retry
import random
@retry()
def test_retry():
if random.randint(0,10) > 1:
print('失敗重試中')
raise Exception
else:
print('成功')
test_retry()

重試次數(shù)
畢竟一直重試需要消耗很多資源,所以我們可以設(shè)置一些重試的次數(shù),比如在失敗多少次后停止重試,不管有沒有成功。
from tenacity import retry,stop_after_attempt
import random
@retry(stop=stop_after_attempt(7))
def test_retry():
# if random.randint(0,10) > 1:
print('失敗重試中')
raise Exception
# else:
# print('成功')
test_retry()

重試時間
也可以設(shè)置執(zhí)行的時間
from tenacity import retry,stop_after_attempt,stop_after_delay
import random
from time import sleep
@retry(stop=stop_after_delay(3))
def test_retry():
# if random.randint(0,10) > 1:
sleep(1)
print('失敗重試中')
raise Exception
# else:
# print('成功')
test_retry()

條件組合
甚至可以使用多個組合條件進行停止,哪個條件先觸發(fā)則執(zhí)行哪個
from tenacity import retry,stop_after_attempt,stop_after_delay
import random
from time import sleep
@retry(stop=stop_after_delay(3) | stop_after_attempt(2))
def test_retry():
# if random.randint(0,10) > 1:
sleep(1)
print('失敗重試中')
raise Exception
# else:
# print('成功')
test_retry()

重試間隔
重試之間的間隔時間太短,所以讓我們在重試之間等待2秒鐘
from tenacity import retry,stop_after_attempt,stop_after_delay,wait_fixed
import random
import time
@retry(wait=wait_fixed(2))
def test_retry():
# if random.randint(0,10) > 1:
print('失敗重試中')
print(time.ctime())
raise Exception
# else:
# print('成功')
test_retry()

重試隨機間隔
我們還可以設(shè)置一些等待時間范圍
from tenacity import retry,stop_after_attempt,stop_after_delay,wait_fixed,wait_random
import random
import time
@retry(wait=wait_random(min=1,max=2))
def test_retry():
# if random.randint(0,10) > 1:
print('失敗重試中')
print(time.ctime())
raise Exception
# else:
# print('成功')
test_retry()

重試前日志
在執(zhí)行之前打印日志
from tenacity import retry,stop_after_attempt,before_log
import logging
import sys
logging.basicConfig(stream=sys.stderr,level=logging.DEBUG)
logger = logging.getLogger(__name__)
@retry(stop=stop_after_attempt(3),before=before_log(logger,logging.DEBUG))
def test_retry():
print('失敗重試中')
raise Exception('Fail')
test_retry()

重試后日志
那么相同的,可以在執(zhí)行失敗后打印日志
from tenacity import retry,stop_after_attempt,after_log
import logging
import sys
logging.basicConfig(stream=sys.stderr,level=logging.DEBUG)
logger = logging.getLogger(__name__)
@retry(stop=stop_after_attempt(3),after=after_log(logger,logging.DEBUG))
def test_retry():
print('失敗重試中')
raise Exception('Fail')
test_retry()

基本常用的功能就這些了,如果有需要深入了解的可以訪問github地址:https://github.com/jd/tenacity
到此這篇關(guān)于關(guān)于Python錯誤重試方法總結(jié)的文章就介紹到這了,更多相關(guān)Python錯誤重試方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解python如何根據(jù)參數(shù)不同調(diào)用不同的類和方法
這篇文章主要為大家詳細介紹了在python中如何根據(jù)參數(shù)不同調(diào)用不同的類和方法,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03
python 多線程實現(xiàn)檢測服務(wù)器在線情況
本文給大家分享的是Python使用多線程通過ping命令檢測服務(wù)器的在線狀況,給大家了內(nèi)網(wǎng)和外網(wǎng)的2個例子,有需要的小伙伴可以參考下。2015-11-11
Python嵌套式數(shù)據(jù)結(jié)構(gòu)實例淺析
這篇文章主要介紹了Python嵌套式數(shù)據(jù)結(jié)構(gòu),結(jié)合實例形式簡單分析了Python字典與列表元素的嵌套存儲相關(guān)定義與操作技巧,需要的朋友可以參考下2019-03-03

