>  기사  >  백엔드 개발  >  Python 데코레이터를 기반으로 클래스의 메서드를 장식합니다.

Python 데코레이터를 기반으로 클래스의 메서드를 장식합니다.

不言
不言원래의
2018-04-21 14:50:532224검색

다음은 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.