回答:
最終的に自分でそれを理解しました。簡単です。辞書をアンパックする**演算子がありませんでした
だから私の例は:
d = dict(p1=1, p2=2)
def f2(p1,p2):
print p1, p2
f2(**d)
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:関数は、辞書に含まれていないパラメーターを持つことができます
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番目の解決策は、関数で使用可能なキーワード引数に基づいて辞書をフィルタリングすることです。
In[11]: import inspect
In[12]: mydict = {'a': 100, 'b': 200, 'c': 300}
In[13]: filtered_mydict = {k: v for k, v in mydict.items() if k in [p.name for p in inspect.signature(myfunc).parameters.values()]}
In[14]: myfunc(**filtered_mydict)
100 200
別のオプションは、関数内の追加のkwargを受け入れる(および無視する)ことです。
In[15]: def myfunc2(a=None, **kwargs):
In[16]: print(a)
In[17]: mydict = {'a': 100, 'b': 200, 'c': 300}
In[18]: myfunc2(**mydict)
100
位置引数とリストまたはタプルを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}
'hello {greeting} {name}'.format( **{'name': 'Andrew', 'greeting': 'Mr'})
Pythonでは、これは「解凍」と呼ばれ、チュートリアルでそれについて少し知ることができます。特にそれがどれほど幻想的に有用であるかという理由で、それの文書化はうんざりです。
ここに行く-他のイテラブルだけで動作します:
d = {'param' : 'test'}
def f(dictionary):
for key in dictionary:
print key
f(d)