Gre*_*edo 4 python lambda python-3.x functools
我正在使用partial库函数为其提供参数之一的默认值
library_func = lambda x, y, z : x + y + z
my_func = functools.partial(library_func, z = 5) #default value for one of the variables
# equiv to lambda x, y : x + y + 5
Run Code Online (Sandbox Code Playgroud)
现在假设我希望 z 依赖于 yeg 的值而不是一个恒定的默认 z,我们在字典中查找 z,其中的键是 y 的不同值。
z = {"1":7,"2":8}[str(y)]
# now my_func(x,y) = library_func(x,y,z = f(y))
Run Code Online (Sandbox Code Playgroud)
这甚至可能吗?在我的用例中,我有一个类保存到数据库的连接 ( self.engine)
self.engine = sqlalchemy.create_engine(connection_string)
self.read_sql = partial(pd.read_sql, con = self.engine)
Run Code Online (Sandbox Code Playgroud)
并pd.read_sql有一个像pd.read_sql(con , name, columns ...)
我想为列设置一个默认值,该值取决于传递的名称值。
我想过
self.read_sql = partial(pd.read_sql, con = self.engine, columns = lambda name: self.name_to_column_dict[name])
Run Code Online (Sandbox Code Playgroud)
但得到错误(有充分的理由!)
您可以改用包装函数:
def my_func(x, y):
return library_func(x, y, {"1":7,"2":8}[str(y)])
Run Code Online (Sandbox Code Playgroud)
或者,如果您不想按照注释中的建议重新键入所有关键字参数,则可以使用inspect.signature获取包装器函数的签名,然后将传入的参数绑定到参数,以便您可以使用 dict 键访问它们, 无论参数是作为位置参数还是作为关键字参数传入:
import inspect
def my_func(*args, **kwargs):
bound = sig.bind(*args, **kwargs)
bound.apply_defaults()
return library_func(**bound.arguments, z={"1":7,"2":8}[str(bound.arguments['y'])])
sig = inspect.signature(my_func)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
226 次 |
| 最近记录: |