在我的代码中,我有很多地方将一个函数及其参数传递给另一个函数。为了调试,我想打印函数的名称和参数列表。例如
def process(f, *args, **kwargs):
print("processing " + print_func(f, args, kwargs))
预期的输出
process(myfunc, 1,2, a="A",b=0)
应该是"processing myfunc(1,2,a="A", b=0)"
我在打印args
方面取得了一些进展,如下所示:
def print_func(f, *args, **kwarg):
func_str = f.__name__ + "("
if len(args) > 0:
func_str = func_str + (', '.join(['%.2f']*len(x)) % args)
func_str = func_str + ")"
在上面的示例中,它将产生输出processing myfunc(1,2)
我的问题是如何打印花格。我找不到使用动态格式字符串将其打印为k=v
对(由“,”分隔)对的序列的类似解决方案。
任何建议将不胜感激。
答案 0 :(得分:0)
要设置args
和kwargs
的格式,您可以简单地遍历它们并创建您的字符串表示形式
def process(my_func, *args, **kwargs):
#Iterate over all args, convert them to str, and join them
args_str = ','.join(map(str,args))
#Iterater over all kwargs, convert them into k=v and join them
kwargs_str = ','.join('{}={}'.format(k,v) for k,v in kwargs.items())
#Or using f-strings
#kwargs_str = ','.join(f'{k}={v}' for k,v in kwargs.items()
#Form the final representation by adding func name
return "processing {}({})".format(my_func.__name__, ','.join([args_str,kwargs_str]))
#Or using f-strings
#return f"processing {my_func.__name__}({','.join([args_str,kwargs_str])})"
print(process(my_func, 1,2, a="A",b=0))
输出将为
processing my_func(1,2,a=A,b=0)
答案 1 :(得分:-1)
您可以通过创建这样的注释来实现
def printArgs(my_func):
def wrapper(*arg, **kwargs):
print("{}({})".format(my_func.__name__, ','.join([str(arg),str(kwargs)])))
return wrapper
@printArgs
def a_function_where_you_want_to_print_args(arg1, arg2, arg3="arg3"):
pass
a_function_where_you_want_to_print_args(1,2, arg3="b")
这将打印“ a_function_where_you_want_to_print_args((1,2),{'arg3':'b'})”