欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Python錯(cuò)誤重試方法總結(jié)

 更新時(shí)間:2021年01月03日 09:22:30   作者:Huny  
在本篇文章里小編給網(wǎng)友們分享一篇關(guān)于關(guān)于Python錯(cuò)誤重試方法總結(jié)內(nèi)容,有需要的朋友們跟著學(xué)習(xí)參考下。

前言

Tenacity是一個(gè) Apache 2.0授權(quán)的通用重試庫(kù),用 Python 編寫,用于簡(jiǎn)化向幾乎所有內(nèi)容添加重試行為的任務(wù)。它起源于一個(gè)重新嘗試的分支,可惜這個(gè)分支已經(jīng)不復(fù)存在了。
使用Tenacity可以用來進(jìn)行測(cè)試用例的重跑,爬蟲腳本的重跑,以及搶票的失敗重?fù)尩鹊?。。??梢允褂玫膱?chǎng)景也是比較多。

使用

首先安裝Tenacity

pip install Tenacity

無限重試

第一個(gè)重試案例,因?yàn)橐恢笔菕伋霎惓ee(cuò)誤,所以無限進(jìn)行重試執(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í)間

也可以設(shè)置執(zhí)行的時(shí)間

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()

條件組合

甚至可以使用多個(gè)組合條件進(jìn)行停止,哪個(gè)條件先觸發(fā)則執(zhí)行哪個(gè)

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()

重試間隔

重試之間的間隔時(shí)間太短,所以讓我們?cè)谥卦囍g等待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()

重試隨機(jī)間隔

我們還可以設(shè)置一些等待時(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錯(cuò)誤重試方法總結(jié)的文章就介紹到這了,更多相關(guān)Python錯(cuò)誤重試方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解python如何根據(jù)參數(shù)不同調(diào)用不同的類和方法

    詳解python如何根據(jù)參數(shù)不同調(diào)用不同的類和方法

    這篇文章主要為大家詳細(xì)介紹了在python中如何根據(jù)參數(shù)不同調(diào)用不同的類和方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-03-03
  • python 多線程實(shí)現(xiàn)檢測(cè)服務(wù)器在線情況

    python 多線程實(shí)現(xiàn)檢測(cè)服務(wù)器在線情況

    本文給大家分享的是Python使用多線程通過ping命令檢測(cè)服務(wù)器的在線狀況,給大家了內(nèi)網(wǎng)和外網(wǎng)的2個(gè)例子,有需要的小伙伴可以參考下。
    2015-11-11
  • 詳解Python中*args和**kwargs的使用

    詳解Python中*args和**kwargs的使用

    本文我們將通過示例了解Python中*args和?**kwargs的使用方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • python中while循環(huán)語句用法簡(jiǎn)單實(shí)例

    python中while循環(huán)語句用法簡(jiǎn)單實(shí)例

    這篇文章主要介紹了python中while循環(huán)語句用法,以一個(gè)簡(jiǎn)單實(shí)例形式分析了Python使用while循環(huán)語句使用方法,需要的朋友可以參考下
    2015-05-05
  • Python編程之Re模塊下的函數(shù)介紹

    Python編程之Re模塊下的函數(shù)介紹

    這篇文章主要介紹了Python編程之Re模塊下的函數(shù)介紹,還是比較不錯(cuò)的,這里分享給大家,供需要的朋友參考。
    2017-10-10
  • python中format函數(shù)如何使用

    python中format函數(shù)如何使用

    在本篇內(nèi)容里小編給大家整理的是一篇關(guān)于python的format函數(shù)用法以及相關(guān)實(shí)例,需要的朋友們學(xué)習(xí)下。
    2020-06-06
  • Python嵌套式數(shù)據(jù)結(jié)構(gòu)實(shí)例淺析

    Python嵌套式數(shù)據(jù)結(jié)構(gòu)實(shí)例淺析

    這篇文章主要介紹了Python嵌套式數(shù)據(jù)結(jié)構(gòu),結(jié)合實(shí)例形式簡(jiǎn)單分析了Python字典與列表元素的嵌套存儲(chǔ)相關(guān)定義與操作技巧,需要的朋友可以參考下
    2019-03-03
  • python實(shí)現(xiàn)按首字母分類查找功能

    python實(shí)現(xiàn)按首字母分類查找功能

    這篇文章主要介紹了python實(shí)現(xiàn)按首字母分類查找功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 教你pycharm快速添加遠(yuǎn)程環(huán)境的詳細(xì)過程

    教你pycharm快速添加遠(yuǎn)程環(huán)境的詳細(xì)過程

    今天通過本文給大家分享pycharm快速添加遠(yuǎn)程環(huán)境的過程,通過在setting中選擇設(shè)置符號(hào)add,具體詳細(xì)過程跟隨小編一起通過本文學(xué)習(xí)下吧
    2021-07-07
  • 跟老齊學(xué)Python之讓人歡喜讓人憂的迭代

    跟老齊學(xué)Python之讓人歡喜讓人憂的迭代

    跟一些比較牛X的程序員交流,經(jīng)常聽到他們嘴里冒出一個(gè)不標(biāo)準(zhǔn)的英文單詞,而loop、iterate、traversal和recursion如果不在其內(nèi),總覺得他還不夠牛X。當(dāng)讓,真正牛X的絕對(duì)不會(huì)這么說的,他們只是說“循環(huán)、迭代、遍歷、遞歸”,然后再問“這個(gè)你懂嗎?”。
    2014-10-10

最新評(píng)論