小编Mic*_*ouw的帖子

Python装饰器记录器

我有以下代码:

def log(func):
    def wrapper(*args, **kwargs):
        func_str = func.__name__
        args_str = ', '.join(args)
        kwargs_str = ', '.join([':'.join([str(j) for j in i]) for i in kwargs.iteritems()])
        with open('log.txt', 'w') as f:
            f.write(func_str)
            f.write(args_str)
            f.write(kwargs_str)
        return func(*args, **kwargs)
    return wrapper()


@log
def example(a, b):
    print('example')
Run Code Online (Sandbox Code Playgroud)

但是,即使没有调用任何函数,我仍然会收到错误:

TypeError: example() takes exactly 2 arguments (0 given)
Run Code Online (Sandbox Code Playgroud)

有人可以向我解释为什么会发生这种情况,因为它似乎调用了函数,但我不明白为什么.

python decorator

8
推荐指数
2
解决办法
4432
查看次数

标签 统计

decorator ×1

python ×1