Source code for pyqqq.utils.retry

import time
from functools import wraps


[docs] def retry(exceptions, total_tries=5, delay=0.5, backoff=2, silently: bool = False): """ 지정된 예외가 발생할 때 함수 실행을 지정된 횟수만큼 재시도하는 데코레이터입니다. 이 데코레이터는 함수를 실행 중 예외가 발생했을 때, 주어진 조건에 따라 자동으로 함수를 재시도합니다. 재시도 간격은 지연시간과 백오프 인자에 의해 결정되며, 모든 시도가 실패하면 최종적으로 예외를 발생시킵니다. Args: exceptions (Exception or tuple): 재시도를 트리거하는 예외 또는 예외 튜플. total_tries (int): 시도할 총 횟수. delay (float): 재시도 간 초기 지연 시간(초). backoff (float): 백오프 인자; 예를 들어, 2는 각 재시도 간 지연 시간을 두 배로 늘립니다. silently (bool): True일 경우 예외 메시지를 출력하지 않습니다. Returns: function: 예외 발생 시 재시도를 수행하는 함수. Examples: >>> @retry(Exception, total_tries=3, delay=1, backoff=1, silently=False) ... def test_func(): ... print("Trying...") ... raise Exception("An error occurred") """ def decorator(func): @wraps(func) def wrapper(*args, **kwargs): current_try = 0 while current_try < total_tries: try: return func(*args, **kwargs) except exceptions as e: current_try += 1 sleep_time = delay * (backoff ** (current_try - 1)) if current_try != total_tries: if not silently: print(f"{str(e)}\nRetrying in {sleep_time} seconds...") time.sleep(sleep_time) else: print("Max retry attempts reached, aborting.") raise return wrapper return decorator