将部分与条件默认参数一起使用

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)

但得到错误(有充分的理由!)

blh*_*ing 5

您可以改用包装函数:

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)