关于Python错误重试方法总结
作者:Huny 时间:2023-05-10 23:42:09
前言
Tenacity是一个 Apache 2.0授权的通用重试库,用 Python 编写,用于简化向几乎所有内容添加重试行为的任务。它起源于一个重新尝试的分支,可惜这个分支已经不复存在了。
使用Tenacity可以用来进行测试用例的重跑,爬虫脚本的重跑,以及抢票的失败重抢等等。。。可以使用的场景也是比较多。
使用
首先安装Tenacity
pip install Tenacity
无限重试
第一个重试案例,因为一直是抛出异常错误,所以无限进行重试执行
from tenacity import retry
@retry()
def test_retry():
print('失败重试中')
raise Exception
test_retry()
成功则停止
我们来优化成功一次后程序则终止,否则继续重试。
from tenacity import retry
import random
@retry()
def test_retry():
if random.randint(0,10) > 1:
print('失败重试中')
raise Exception
else:
print('成功')
test_retry()
重试次数
毕竟一直重试需要消耗很多资源,所以我们可以设置一些重试的次数,比如在失败多少次后停止重试,不管有没有成功。
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()
重试时间
也可以设置执行的时间
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()
条件组合
甚至可以使用多个组合条件进行停止,哪个条件先触发则执行哪个
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()
重试前日志
在执行之前打印日志
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()
重试后日志
那么相同的,可以在执行失败后打印日志
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
来源:https://www.cnblogs.com/huny/p/14223952.html
标签:Python,错误重试
0
投稿
猜你喜欢
Python制作当年第一款手机游戏-贪吃蛇游戏(练习)
2022-06-20 02:37:35
php+ajax+h5实现图片上传功能
2024-05-22 10:05:39
python-docx 页面设置详解
2021-12-06 03:42:02
解决django FileFIELD的编码问题
2023-07-01 04:28:42
Python 异常处理的实例详解
2023-10-05 17:11:58
如何用Python徒手写线性回归
2023-06-12 13:47:14
js页面文字选中后分享到新浪微博实现
2011-03-17 12:55:00
Python技能树共建之python urllib 模块
2023-02-07 04:02:40
MySQL数据库数据备份和恢复详解
2009-07-15 10:51:00
Python实现的简单模板引擎功能示例
2022-01-24 04:47:36
Windows版Mysql5.6.11的安装与配置教程
2024-01-24 18:24:48
Python爬取网易云音乐热门评论
2022-06-16 00:24:58
在Vue-cli里应用Vuex的state和mutations方法
2024-04-29 13:09:51
vue封装axios与api接口管理的完整步骤
2024-04-30 10:28:24
公网远程访问局域网SQL Server数据库
2024-01-22 01:38:21
Bootstrap表格和栅格分页实例详解
2024-04-10 13:51:05
运用ASP调用数据库中视图及存储过程
2008-02-03 15:33:00
使用Python编写一个最基础的代码解释器的要点解析
2023-07-16 11:47:22
golang与pgsql交互的实现
2024-05-25 15:11:52
PHP PDOStatement::bindParam讲解
2023-06-05 05:47:28