다음은 Python 데코레이터 장식 클래스의 메소드 예제를 기반으로 한 기사입니다. 참고할 가치가 높으며 모든 사람에게 도움이 되기를 바랍니다. 함께 살펴볼까요
제목: Python 데코레이터 장식 클래스의 메서드
댓글: true
날짜: 2017-04-17 20:44:31
태그: ['Python', '장식']
카테고리: ['Python']
---
현재 중국 인터넷에서 검색할 수 있는 데코레이터에 대한 튜토리얼의 대부분은 일반적인 기능을 꾸미는 방법에 관한 것입니다. 이 글에서는 Python의 데코레이터를 사용하여 클래스 메서드를 장식하고 데코레이터 함수에서 클래스의 다른 메서드를 호출하는 방법을 소개합니다. 이 문서에서는 설명을 위한 예로 메서드에서 예외를 포착합니다.
Test라는 클래스가 있는데, 그 구조는 다음과 같습니다:
class Test(object): def __init__(self): pass def revive(self): print('revive from exception.') # do something to restore def read_value(self): print('here I will do something.') # do something.
클래스에 read_value() 메소드가 있는데, 이 메소드는 여러 곳에서 호출됩니다. 어떤 이유로 read_value 메소드가 무작위로 Exception을 발생시키고 프로그램 충돌을 일으킬 수 있습니다. 따라서 try...전체 메소드에 대한 처리를 제외하고 수행해야 합니다. 가장 추악한 접근 방식은 다음 코드에 나와 있습니다.
class Test(object): def __init__(self): pass def revive(self): print('revive from exception.') # do something to restore def read_value(self): try: print('here I will do something.') # do something. except Exception as e: print(f'exception {e} raised, parse exception.') # do other thing. self.revive()
이와 같이 작성하면 문제를 해결할 수 있지만 코드는 Pythonic이 아닙니다.
이 문제를 해결하려면 데코레이터를 사용하세요. 데코레이터 기능을 클래스 내부에 작성해야 할까요, 아니면 클래스 외부에 작성해야 할까요? 대답은 수업 밖에서 작성하는 것입니다. 그러면 클래스 외부에 작성되었으므로 이 클래스의 다른 메서드를 어떻게 호출합니까?
먼저 예외 처리를 위한 가장 일반적인 데코레이터를 작성합니다:
def catch_exception(origin_func): def wrapper(*args, **kwargs): try: u = origin_func(*args, **kwargs) return u except Exception: return 'an Exception raised.' return wrapper class Test(object): def __init__(self): pass def revive(self): print('revive from exception.') # do something to restore @catch_exception def read_value(self): print('here I will do something.') # do something.
이러한 작성 방법은 실제로 Origin_func()의 예외를 캡처할 수 있지만 예외가 발생하면 다른 메서드를 호출해야 합니다. 클래스에서 예외를 처리하려면 어떻게 해야 하나요? 대답은 래퍼 self.
에 매개변수를 추가하는 것입니다. 코드는 다음 형식으로 변경됩니다.
def catch_exception(origin_func): def wrapper(self, *args, **kwargs): try: u = origin_func(self, *args, **kwargs) return u except Exception: self.revive() #不用顾虑,直接调用原来的类的方法 return 'an Exception raised.' return wrapper class Test(object): def __init__(self): pass def revive(self): print('revive from exception.') # do something to restore @catch_exception def read_value(self): print('here I will do something.') # do something.
데코레이터에서 정의한 부분만 수정하면 되며 수정이 필요하지 않습니다. 데코레이터가 사용되는 곳.
다음 그림은 정상 작동 중 실행 결과를 보여줍니다.
다음 그림은 예외 발생 후 예외를 포착하고 처리하는 모습을 보여줍니다.
자체 매개 변수를 추가하면 외부 데코레이터가 클래스는 클래스에서 다양한 메소드를 직접 사용할 수도 있고, 클래스의 속성을 직접 사용할 수도 있습니다.
관련 권장사항:
python 데코레이터 - 함수 호출 수를 제한하는 방법(10초마다 한 번씩 호출)
위 내용은 Python 데코레이터를 기반으로 클래스의 메서드를 장식합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!