亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關于Python錯誤重試方法總結

 更新時間:2021年01月03日 09:22:30   作者:Huny  
在本篇文章里小編給網友們分享一篇關于關于Python錯誤重試方法總結內容,有需要的朋友們跟著學習參考下。

前言

Tenacity是一個 Apache 2.0授權的通用重試庫,用 Python 編寫,用于簡化向幾乎所有內容添加重試行為的任務。它起源于一個重新嘗試的分支,可惜這個分支已經不復存在了。
使用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ù),比如在失敗多少次后停止重試,不管有沒有成功。

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

重試時間

也可以設置執(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()

重試隨機間隔

我們還可以設置一些等待時間范圍

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

到此這篇關于關于Python錯誤重試方法總結的文章就介紹到這了,更多相關Python錯誤重試方法內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

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

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

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

    python 多線程實現(xiàn)檢測服務器在線情況

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

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

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

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

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

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

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

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

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

    Python嵌套式數(shù)據結構實例淺析

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

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

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

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

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

    跟老齊學Python之讓人歡喜讓人憂的迭代

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

最新評論