为了漂亮地打印我的计算结果,我写了一个装饰器。
from functools import wraps
def print_disp(f):
@wraps(f)
def wrapping(*args, **kwargs):
disp, disp_std = f(*args, **kwargs)
labels = ('GD', 'GDD','TOD', 'FOD', 'QOD')
for i, (label, disp_item, disp_std_item) in enumerate(zip(labels, disp, disp_std)):
print(f'{label} = {disp_item:.5f} ± {disp_std_item:.5f} fs^{i+1}')
return disp, disp_std
return wrapping
可以用下面的方法。
import numpy as np
@print_disp
def calc():
disp = np.array([1, 0, 7, 0, 0])
disp_std = np.array([0.1, 0, 0.7, 0, 0])
return disp, disp_std
然后它就会返回
GD = 1.00000 ± 0.10000 fs^1
GDD = 0.00000 ± 0.00000 fs^2
TOD = 7.00000 ± 0.70000 fs^3
FOD = 0.00000 ± 0.00000 fs^4
QOD = 0.00000 ± 0.00000 fs^5
这很好。但是,我想避免打印多余的0行,但我只想修剪掉最后的0,所以GDD=0这一行应该留下来。由于这个原因,我不能添加类似这样的内容 if disp item != 0: print(..)
到装饰者主体。想要的行为是。
GD = 1.00000 ± 0.10000 fs^1
GDD = 0.00000 ± 0.00000 fs^2
TOD = 7.00000 ± 0.70000 fs^3
我怎么解决这个问题?
如果你想只打印带零的第一行,你可以像这样修改装饰器来跟踪是否打印了这样的一行。
def print_disp(f):
@wraps(f)
def wrapping(*args, **kwargs):
zero_printed = False
disp, disp_std = f(*args, **kwargs)
labels = ('GD', 'GDD','TOD', 'FOD', 'QOD')
for i, (label, disp_item, disp_std_item) in enumerate(zip(labels, disp, disp_std)):
if disp_item == 0 and zero_printed:
continue
zero_printed |= disp_item == 0
print(f'{label} = {disp_item:.5f} ± {disp_std_item:.5f} fs^{i+1}')
return disp, disp_std
return wrapping
你可以这样做
from functools import wraps
def print_disp(f):
@wraps(f)
def wrapping(*args, **kwargs):
disp, disp_std = f(*args, **kwargs)
labels = ('GD', 'GDD','TOD', 'FOD', 'QOD')
for i, (label, disp_item, disp_std_item) in enumerate(zip(labels, disp, disp_std)):
if sum(disp[i:])+sum(disp_std[i:]) == 0:
break
print(f'{label} = {disp_item:.5f} ± {disp_std_item:.5f} fs^{i+1}')
last_item = disp_item+disp_std_item
return disp, disp_std
return wrapping