-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathzhuanshiqi2.py
More file actions
91 lines (76 loc) · 2.26 KB
/
zhuanshiqi2.py
File metadata and controls
91 lines (76 loc) · 2.26 KB
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#! /usr/bin/env python
# -*- coding: utf-8 -*-
# vim:fenc=utf-8
#
# Copyright © 2020 ubuntu <ubuntu@VM-0-13-ubuntu>
#
# Distributed under terms of the MIT license.
"""
"""
import functools
def logged(level):
if not callable(level):
def _deco(func):
@functools.wraps(func)
def _deco(*args, **kwargs):
print("decorate has argument")
print('arguments is {}'.format(level))
return func(*args, **kwargs)
return _deco
return _deco
else:
@functools.wraps(level)
def _deco(*args, **kwargs):
print("decorate doesn't has argemunt")
level(*args, **kwargs)
return _deco
def logging(level):
def _deco(func):
@functools.wraps(func)
def _deco(*args, **kwargs):
if level == 'warn':
print('{} is warning logging running, please lookup'.format(func.__name__))
return func(*args, **kwargs)
return _deco
return _deco
def use_logging(func):
@functools.wraps(func)
def _deco(*args, **kwargs):
print("{} is use_logging running".format(func.__name__))
print("all function complete")
return func(*args, **kwargs)
return _deco
#@logging('pass')
#@use_logging
def bar(a,b):
print('i am bar, result is {}'.format(a*b))
#bar(2,5)
class Log_class:
def __init__(self, args='warn'):
self.args = args
def __call__(self, func):
@functools.wraps(func)
def _deco(*args, **kwargs):
if self.args == 'warn':
self.notify(func)
return func(*args, **kwargs)
return _deco
def notify(self, func):
print('{} is running'.format(func.__name__))
class email_log(Log_class):
def __init__(self, email='wmsj100@hotmail.com', *args, **kwargs):
self.email = email
super().__init__(*args, **kwargs)
def notify(self, func):
print('Please send email to {}'.format(self.email))
print('{} is running'.format(func.__name__))
#@Log_class(args='warning')
@email_log(args='warning')
#@logged('wmsj param')
#@logged
#@logging('warn')
#@use_logging
def bar2(a,b,c,d):
print('i am bar2, data is {}'.format(a+b+c+d))
print(bar2.__name__)
bar2(4,3,5,6)