Python 如何知道函数方法的decorator中的类名?
我有一个简单的时间标记装饰功能:Python 如何知道函数方法的decorator中的类名?,python,Python,我有一个简单的时间标记装饰功能: def dec_timemark(f): def tmp(*args, **kwargs): sys.stdout.write(strftime("%d.%m.%Y %H:%M:%S") + ' ' + f.__name__ + ' begin' + "\n" ) res = f(*args, **kwargs
def dec_timemark(f):
def tmp(*args, **kwargs):
sys.stdout.write(strftime("%d.%m.%Y %H:%M:%S") + ' ' + f.__name__ +
' begin' + "\n" )
res = f(*args, **kwargs)
sys.stdout.write(strftime("%d.%m.%Y %H:%M:%S") + ' ' + f.__name__ +
' end' + "\n" )
return res
return tmp
典型用法:
class Task():
@dec_timemark
def make_torrent():
sleep(10)
但是如何将
类的名称添加到这个装饰器中呢?(不记录:“make_torrent begin
”,而是“Task.make_torrent begin
”)假设修饰例程作为方法调用,您可以从self
参数中提取类名:
def dump(f):
def decorated(self, *args, **kwargs):
print 'Class: {0}'.format(self.__class__.__name__)
print 'Args passed to decorated function: {0}'.format(args)
print 'Keyword args passed to decorated function: {0}'.format(kwargs)
return f(self, *args, **kwargs)
return decorated
class Test(object):
"""
>>> Test().test('arg1', 'arg2', kwarg1='kwval1')
Class: Test
Args passed to decorated function: ('arg1', 'arg2')
Keyword args passed to decorated function: {'kwarg1': 'kwval1'}
"""
@dump
def test(*args, **kwargs):
pass
在dec\u timemark()
本身的范围内无法访问该信息,因为该类尚不存在。但是,当调用tmp()
时,第一个参数将是self
,因为.make\u torrent()
是作为实例方法调用的。因此,type(self)。\uuuu name\uuuu
应该为您提供类名
修改您的示例:
def dec_timemark(f):
def tmp(self, *args, **kwargs):
cname = type(self).__name__
sys.stdout.write(strftime("%d.%m.%Y %H:%M:%S") + ' ' + cname + '.' + f.__name__ +
' begin' + "\n" )
res = f(self, *args, **kwargs)
sys.stdout.write(strftime("%d.%m.%Y %H:%M:%S") + ' ' + cname + '.' + f.__name__ +
' end' + "\n" )
return res
return tmp
self.\uuuuu name\uuuuu
不起作用。您必须访问类的属性,而不是实例。