@decorate
def func():
pass
#! 等价于
func = decorate(func)
def a_new_decorator(a_func):
def wrapTheFunction():
print("I am doing some boring work before executing a_func()")
a_func()
print("I am doing some boring work after executing a_func()")
return wrapTheFunction
@a_new_decorator
def a_function_requiring_decoration():
"""Hey yo! Decorate me!"""
print("I am the function which needs some decoration to remove my foul smell")
a_function_requiring_decoration()
# Output: I am doing some boring work before executing a_func()
# I am the function which needs some decoration to remove my foul smell
# I am doing some boring work after executing a_func()
print(a_function_requiring_decoration.__name__)
# Output: wrapTheFunction
实际上我们希望"name"函数输出函数的名字,这样在后续代码排查的时候可以提高效率,但是这里的函数被wrapTheFunction代替了,重写了我们的函数名字和注释文档。因此在python需要借用functools.warps来解决这个问题。
def a_new_decorator(a_func):
@wrap(a_func)
def wrapTheFunction():
print("I am doing some boring work before executing a_func()")
a_func()
print("I am doing some boring work after executing a_func()")
return wrapTheFunction
@a_new_decorator
def a_function_requiring_decoration():
"""Hey yo! Decorate me!"""
print("I am the function which needs some decoration to remove my foul smell")
a_function_requiring_decoration()
# Output: I am doing some boring work before executing a_func()
# I am the function which needs some decoration to remove my foul smell
# I am doing some boring work after executing a_func()
print(a_function_requiring_decoration.__name__)
# Output:a_function_requiring_decoratio
from functools import wraps
def logit(logfile='out.log'):
def logging_decorator(func):
@wraps(func)
def wrapped_function(*args, **kwargs):
log_string = func.__name__ + " was called"
print(log_string)
# 打开logfile,并写入内容
with open(logfile, 'a') as opened_file:
# 现在将日志打到指定的logfile
opened_file.write(log_string + '\n')
return func(*args, **kwargs)
return wrapped_function
return logging_decorator
@logit()
def myfunc1():
pass
myfunc1()
# Output: myfunc1 was called
# 现在一个叫做 out.log 的文件出现了,里面的内容就是上面的字符串
@logit(logfile='func2.log')
def myfunc2():
pass
myfunc2()
# Output: myfunc2 was called
# 现在一个叫做 func2.log 的文件出现了,里面的内容就是上面的字符串
在 Python 的 “Registry”(注册器)模式中,参数 “parent” 通常表示父级对象或父级注册器。“Registry” 模式用于管理、存储和检索对象、函数或其他实体,允许不同的组件或模块向注册器中注册或注销实体,然后其他组件可以查询并使用这些实体。
当在 “Registry” 模式中使用参数 “parent” 时,通常是指在注册一个实体时,需要将其关联到某个父级对象或父级注册器。这可以用于创建层次结构、管理依赖关系或组织数据。
下面是一个示例,展示了在 “Registry” 模式中使用参数 “parent” 的可能含义:
class Registry:
def __init__(self):
self._registry = {}
def register(self, name, item, parent=None):
if parent is not None:
parent.register(name, item)
else:
self._registry[name] = item
# 使用示例
root_registry = Registry()
child_registry = Registry()
root_registry.register("item_a", "Item A")
child_registry.register("item_b", "Item B", parent=root_registry)
在这个示例中,我们定义了一个 “Registry” 类,其中的 register 方法接受参数 “parent”。当注册实体时,如果指定了 “parent” 参数,那么实体将被注册到父级注册器中,否则将被注册到当前注册器中。这允许我们创建层次结构的注册器,其中子注册器可以继承父注册器中的实体。
需要注意的是,具体的含义和用法可能会根据你的需求和实现方式而有所不同。在 “Registry” 模式中,参数 “parent” 的含义取决于你如何设计和使用注册器。
注册 构建