關于Python錯誤重試方法總結
Tenacity是一個 Apache 2.0授權的通用重試庫,用 Python 編寫,用于簡化向幾乎所有內(nèi)容添加重試行為的任務。它起源于一個重新嘗試的分支,可惜這個分支已經(jīng)不復存在了。使用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 retryimport random@retry()def test_retry(): if random.randint(0,10) > 1: print(’失敗重試中’) raise Exception else: print(’成功’)test_retry()
重試次數(shù)
畢竟一直重試需要消耗很多資源,所以我們可以設置一些重試的次數(shù),比如在失敗多少次后停止重試,不管有沒有成功。
from tenacity import retry,stop_after_attemptimport random@retry(stop=stop_after_attempt(7))def test_retry(): # if random.randint(0,10) > 1: print(’失敗重試中’) raise Exception # else: # print(’成功’)test_retry()
重試時間
也可以設置執(zhí)行的時間
from tenacity import retry,stop_after_attempt,stop_after_delayimport randomfrom 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_delayimport randomfrom 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_fixedimport randomimport 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()
重試隨機間隔
我們還可以設置一些等待時間范圍
from tenacity import retry,stop_after_attempt,stop_after_delay,wait_fixed,wait_randomimport randomimport 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_logimport loggingimport syslogging.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_logimport loggingimport syslogging.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
到此這篇關于關于Python錯誤重試方法總結的文章就介紹到這了,更多相關Python錯誤重試方法內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網(wǎng)!
相關文章:
1. 通過CSS數(shù)學函數(shù)實現(xiàn)動畫特效2. CSS3中Transition屬性詳解以及示例分享3. 阿里前端開發(fā)中的規(guī)范要求4. 低版本IE正常運行HTML5+CSS3網(wǎng)站的3種解決方案5. 利用CSS3新特性創(chuàng)建透明邊框三角6. XML入門的常見問題(二)7. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)8. IE6/IE7/IE8/IE9中tbody的innerHTML不能賦值的完美解決方案9. XML入門的常見問題(一)10. 解析原生JS getComputedStyle
