카테고리 보관물: 파이썬

파이썬

키워드 매개 변수로 함수에 사전 전달 {‘param’: ‘test’} 되지만 인쇄 하기를 원합니다.

사전을 사용하여 파이썬에서 함수를 호출하고 싶습니다.

다음은 몇 가지 코드입니다.

d = dict(param='test')

def f(param):
    print(param)

f(d)

이것은 인쇄 {'param': 'test'}되지만 인쇄 하기를 원합니다

더 많은 매개 변수에 대해 비슷하게 작동하고 싶습니다.

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

이게 가능한가요?



답변

결국 나 자신을 위해 테스트하다 그것을 알아 냈습니다. 간단합니다. 사전을 풀기 위해 ** 연산자가 누락되었습니다.

그래서 내 예는 다음과 같습니다.

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. 함수 에는 사전에 포함 되지 않은 매개 변수가있을 수 있습니다.
  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에 대한 해결책 은 함수에서 사용 가능한 키워드 인수를 기반으로 사전을 필터링하는 것입니다.

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

다른 옵션은 함수에서 추가

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}

답변

파이썬에서는 이것을 “포장 풀기”라고하며, 튜토리얼 에서 그것에 대해 조금 찾을 수 있습니다 .


답변

여기서 나중에 간다 는 다른 반복 가능하게 작동합니다.

d = {'param' : 'test'}

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

f(d)