422

我想使用字典在 python 中调用一个函数。

这是一些代码:

d = dict(param='test')

def f(param):
    print(param)

f(d)

这会打印{'param': 'test'},但我希望它只是 print test

我希望它对更多参数有类似的工作:

d = dict(p1=1, p2=2)
def f2(p1, p2):
    print(p1, p2)
f2(d)

这可能吗?

4

4 回答 4

636

最后自己想通了。很简单,我只是缺少 ** 运算符来解包字典

所以我的例子变成了:

d = dict(p1=1, p2=2)
def f2(p1,p2):
    print p1, p2
f2(**d)
于 2008-12-02T16:53:34.640 回答
179
In[1]: def myfunc(a=1, b=2):
In[2]:    print(a, b)

In[3]: mydict = {'a': 100, 'b': 200}

In[4]: myfunc(**mydict)
100 200

一些可能有助于了解的额外细节(我在阅读本文并进行测试后遇到的问题):

  1. 该函数可以具有字典中未包含的参数
  2. 不能覆盖字典中已经存在的函数参数
  3. 字典不能包含不在函数中的值。

例子:

数字 1:函数可以有字典中没有的参数

In[5]: mydict = {'a': 100}
In[6]: myfunc(**mydict)
100 2

数字 2:您不能覆盖字典中已经存在的函数参数

In[7]: mydict = {'a': 100, 'b': 200}
In[8]: myfunc(a=3, **mydict)

TypeError: myfunc() got multiple values for keyword argument 'a'

数字 3:字典不能包含不在函数中的值。

In[9]:  mydict = {'a': 100, 'b': 200, 'c': 300}
In[10]: myfunc(**mydict)

TypeError: myfunc() got an unexpected keyword argument 'c'

如何使用键多于函数参数的字典:

上面 #3 的解决方案是在你的函数中接受(并忽略)额外的 kwargs(注意,按照惯例_,变量名用于被丢弃的东西,尽管从技术上讲,它只是 Python 的有效变量名):

In[11]: def myfunc2(a=None, **_):
In[12]:    print(a)

In[13]: mydict = {'a': 100, 'b': 200, 'c': 300}

In[14]: myfunc2(**mydict)
100

另一种选择是根据函数中可用的关键字参数过滤字典:

In[15]: import inspect
In[16]: mydict = {'a': 100, 'b': 200, 'c': 300}
In[17]: filtered_mydict = {k: v for k, v in mydict.items() if k in [p.name for p in inspect.signature(myfunc).parameters.values()]}
In[18]: myfunc(**filtered_mydict)
100 200

具有位置和关键字参数的示例:

请注意,您可以像使用 kwargs 一样有效地使用位置参数和列表或元组,这是一个更高级的示例,它结合了位置参数和关键字参数:

In[19]: def myfunc3(a, *posargs, b=2, **kwargs):
In[20]:    print(a, b)
In[21]:    print(posargs)
In[22]:    print(kwargs)

In[23]: mylist = [10, 20, 30]
In[24]: mydict = {'b': 200, 'c': 300}

In[25]: myfunc3(*mylist, **mydict)
10 200
(20, 30)
{'c': 300}
于 2017-04-05T18:29:25.693 回答
36

在 python 中,这称为“解包”,您可以在教程中找到一些相关信息。我同意它的文档很烂,尤其是因为它非常有用。

于 2008-12-02T22:03:11.240 回答
5

在这里你去 - 适用于任何其他可迭代:

d = {'param' : 'test'}

def f(dictionary):
    for key in dictionary:
        print key

f(d)
于 2008-12-02T16:52:20.227 回答