我想创建一个函数作为另一个函数的装饰器将打印该函数调用详细信息 - 参数名称和有效值。我目前的实现是这样的。
def describeFuncCall(func):
"""
Decorator to print function call details.
parameters names and effective values.
"""
def wrapper(*func_args, **func_kwargs):
print "func_code.co_varnames =", func.func_code.co_varnames
print "func_code.co_argcount =", func.func_code.co_argcount
print "func_args =", func_args
print "func_kwargs =", func_kwargs
params = []
for argNo in range(func.func_code.co_argcount):
argName = func.func_code.co_varnames[argNo]
argValue = (
func_args[argNo]
if argNo < len(func_args)
else func.func_defaults[argNo - func.func_code.co_argcount]
)
params.append((argName, argValue))
for argName, argValue in func_kwargs.items():
params.append((argName, argValue))
params = [argName + " = " + repr(argValue)
for argName, argValue in params]
print (func.__name__ + " ( " + ", ".join(params) + " )")
return func(*func_args, **func_kwargs)
return wrapper
@describeFuncCall
def test(a, b=4, c="blah-blah", *args, **kwargs):
pass
test(1)
# test(1, 3)
# test(1, d = 5)
test(1, 2, 3, 4, 5, d=6, g=12.9)
有点工作,但有一些错误:
打电话
test(1, 2, 3, 4, 5, d = 6, g = 12.9)
它打印
test ( a = 1, b = 2, c = 3, d = 6, g = 12.9 )
。
预期的结果是
test ( a = 1, b = 2, c = 3, args = [4, 5], kwargs = {'d': 6, 'g': 12.9} )
我被困在这里了。你能帮我找到正确的解决方案吗?
原文由 warvariuc 发布,翻译遵循 CC BY-SA 4.0 许可协议
抱歉有点乱。我修改了 PythonDecoratorLibrary 中 Easy Dump of Function Arguments 中的一些代码。
输出: