티스토리 뷰
[Decorator: func]
- 로그를 남길때
- 성능을 측정할 때
- 유저의 상태를 남기기 위한 redirect
[performance.py]
일반 함수에 사용될 경우
import time
def stop_watch(func):
def wrapper(*args, **kwargs):
start = time.time()
result = func(*args, **kwargs)
print("{}: delay={}".format(func.__name__, time.time()-start))
return result
return wrapper
class 함수에 사용될 경우 인자 맨앞에 self 를 위치 시킨다.
import time
def stop_watch(func):
def wrapper(self, *args, **kwargs):
start = time.time()
result = func(self, *args, **kwargs)
print("{}: delay={}".format(func.__name__, time.time()-start))
return result
return wrapper
[main.py]
import performance
def is_prime(n):
for i in range(2, n):
if n % i == 0:
return False
return True
@performance.stop_watch
def count_prime(n):
cnt = 0
for i in range(2, n+1):
if is_prime(i):
cnt += 1
return cnt
print(count_prime(30000))
[Decorator: class]
위의 decorator 를 클래스로 구현해 보자
class Deco:
def __init__(self, func):
self.func = func
def __call__(self, *args, **kwargs):
import time
start = time.time()
result = self.func(*args, **kwargs)
print("{}: delay={}".format(self.func.__name__, time.time()-start))
return result
def is_prime(n):
for i in range(2, n):
if n % i == 0:
return False
return True
@Deco
def count_prime(n):
cnt = 0
for i in range(2, n+1):
if is_prime(i):
cnt += 1
return cnt
이렇게도 구현 가능하다
class Cls:
class Decorator:
def __init__(self, *args, **kwargs):
self.args = args
self.kwargs = kwargs
def __call__(self, func):
@wraps(func)
def wrapper(*args, **kwargs):
print("start decorator", self.args, self.kwargs)
return func(*args, *kwargs)
return wrapper
def __init__(self):
pass
@Decorator(1, 2, 3, age="20", name="kim")
def foo(self):
print("start foo")
return -1
c = Cls()
print(c.foo())
'python lecture > basic' 카테고리의 다른 글
[edu] 파이썬 시작하기 - 12 (deque) (0) | 2018.09.24 |
---|---|
[edu] 파이썬 시작하기 - 11 (thread) (0) | 2018.09.24 |
[edu] 파이썬 시작하기 - 8 (0) | 2018.08.29 |
[edu] 파이썬 시작하기 - 6 (0) | 2018.08.28 |
[edu] 파이썬 시작하기 - 5 (0) | 2018.08.27 |
- Total
- Today
- Yesterday
- 파이썬 프로그래밍
- 문서 비교
- django
- django chatbot
- gitlab
- 파이썬 강좌
- 파이썬
- 장고
- 엑셀 비교
- 이미지 비교
- pycrypto
- 모바일 스킨 적용
- 모바일 테마 적용
- 면접정답
- 장고 플러스친구 자동응답
- wsgi
- PuTTYGen
- 문과 코딩
- 플러스친구 자동응답
- gitignore
- 파이썬 입문
- 파이썬 독학
- virtualenv
- GIT
- Tistory
- chatbot
- 장고 카톡 자동응답
- 면접답변
- Python
- admin.py
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |