python重试装饰器(Python function retry decorator)
在用requests请求接口或者html的时候,很容易出现超时,限制等各种原因。
在对源代码不进行修改的情况下,可以用装饰器来进行重试
任何函数: 成功,返回-结果,失败,返回--False 都可以用这个装饰器进行重试
1.不需要传参的装饰器写法:
max_retry 为默认重试的次数
import requests
def retry(func):
def inner(*args, **kwargs):
ret = func(*args, **kwargs)
max_retry = 3
number = 0
if not ret:
while number < max_retry:
number += 1
print("尝试第:{}次".format(number))
result = func(*args, **kwargs)
if result:
break
return inner
@retry
def get_reponse():
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36'
}
url = 'https://www.baidu.com'
try:
r = requests.get(url=url, headers=headers, timeout=0.01)
if r.status_code == 200:
print(r.headers)
return r.headers
except requests.exceptions.ReadTimeout:
return False
except requests.exceptions.ConnectTimeout:
return False
except Exception:
return False
get_reponse()
执行结果:
尝试第:1次
尝试第:2次
尝试第:3次
2.需要传参的装饰器写法:
def retry(*args, **kwargs):
def warpp(func):
def inner():
ret = func()
max_retry = kwargs.get('max_retry')
# 不传默认重试3次
if not max_retry:
max_retry = 3
number = 0
if not ret:
while number < max_retry:
number += 1
print("尝试第:{}次".format(number))
result = func()
if result:
break
return inner
return warpp
@retry(max_retry=5) # 不传默认为3次 @retry() 括号需要带
def get_reponse():
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36'
}
url = 'https://www.baidu.com'
try:
r = requests.get(url=url, headers=headers, timeout=0.01)
if r.status_code == 200:
print(r.headers)
return r.headers
except requests.exceptions.ReadTimeout:
return False
except requests.exceptions.ConnectTimeout:
return False
except Exception:
return False
get_reponse()
执行结果:
尝试第:1次
尝试第:2次
尝试第:3次
尝试第:4次
尝试第:5次
3. 装饰器在类的用法
import requests
class Test:
def retry(*args, **kwargs):
def warpp(func):
def inner(self, *args, **kwargs):
ret = func(self, *args, **kwargs)
max_retry = kwargs.get('max_retry')
# 不传默认重试3次
if not max_retry:
max_retry = 3
number = 0
if not ret:
while number < max_retry:
number += 1
print("尝试第:{}次".format(number))
result = func(self, *args, **kwargs)
if result:
break
return inner
return warpp
@retry()
def get_reponse(self, url):
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/73.0.3683.103 Safari/537.36'
}
try:
r = requests.get(url=url, headers=headers, timeout=0.01)
if r.status_code == 200:
print(r.headers)
return r.headers
except requests.exceptions.ReadTimeout:
return False
except requests.exceptions.ConnectTimeout:
return False
except Exception:
return False
if __name__ == '__main__':
st = Test()
url = 'https://www.baidu.com'
st.get_reponse(url)
运行结果:
尝试第:1次
尝试第:2次
尝试第:3次
最后
俺叫小枫,一个成天想着一夜暴富的测试员
(1140267353)一起成长一起加油的伙伴群!软件测试,与你同行!
群内可领取小枫给大家准备的最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!
点赞评论关注不迷路!!!【三连?】,有问题也可私聊哟~(*?▽?*)

这篇博客介绍了如何使用Python装饰器实现重试机制,适用于请求接口或处理可能出现异常的情况。提供了不需要传参和需要传参的装饰器示例,并展示了在类中使用装饰器的用法。通过装饰器,可以方便地对函数进行重试,提高程序的健壮性。

1109

被折叠的 条评论
为什么被折叠?



