Develop
2019.11.22 03:30
[python] 파라미터 앞에 *, ** 의 의미? (*args, **kwargs)
조회 수 1553 댓글 0
python 코드를 보다보면
*args, **kwargs 를 심심치 않게 본다.
그냥 막연하게 "어떤 파라미터를 몇개를 받을지 모르는 경우 사용한다" 라고 알고 있었지만
자세히 설명한 예 가 있어서 소개한다.
*args
- 파라미터를 몇개를 받을지 모르는 경우 사용한다. args 는 튜플 형태로 전달된다.
예)
def print_param(*args):
print args
for p in args:
print p
print_param('a', 'b', 'c', 'd')
#('a', 'b', 'c', 'd')
#a
#b
#c
#d
**kwargs
- 파라미터 명을 같이 보낼 수 있다. kwargs는 딕셔너리 형태로 전달된다.
def print_param2(**kwargs):
print kwargs
print kwargs.keys()
print kwargs.values()
for name, value in kwargs.items():
print "%s : %s" % (name, value)
print_param2(first = 'a', second = 'b', third = 'c', fourth = 'd')
#{'second': 'b', 'fourth': 'd', 'third': 'c', 'first': 'a'}
#['second', 'fourth', 'third', 'first']
#['b', 'd', 'c', 'a']
#second : b
#fourth : d
#third : c
#first : a
그러면 두개를 같이 쓰는 경우는??
def print_param3(*args, **kwargs):
print args
print kwargs
print_param3('a', 'b')
#('a', 'b')
#{}
print_param3(third = 'c', fourth = 'd')
#()
#{'fourth': 'd', 'third': 'c'}
print_param3('a', 'b', third = 'c', fourth = 'd')
#('a', 'b')
#{'fourth': 'd', 'third': 'c'}
응용 해 보자
def print_param4(a, b, c):
print a, b, c
p = ['a', 'b', 'c']
print_param4(*p)
#a b c
p2 = {'c' : '1', 'a' : '2', 'b' : '3'}
print_param4(**p2)
#2 3 1
[출처] https://www.geeksforgeeks.org/args-kwargs-python/
[참고] https://stackoverflow.com/questions/3394835/use-of-args-and-kwargs
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
23 | Database | [mysql] 접속과 테이블 생성 간단한 설명.. | hooni | 2003.04.23 | 18655 |
22 | Database | [mysql] 쿼리 로그 저장 매뉴얼 | hooni | 2013.04.23 | 15216 |
21 | Database | [sql] 간단한 통계 서브쿼리 예제.. | hooni | 2013.04.23 | 15088 |
20 | Database | [mysql] 쓰레드가 계속 쌓이기 시작하고 사라지지 않을때.. | hooni | 2003.04.23 | 12787 |
19 | Database | [mysql] error while loading shared libraries: libmysqlclient.so.10: | hooni | 2003.04.23 | 12663 |
18 | Database | [sql] 간단한 SQL 문법 정리 | hooni | 2003.04.23 | 12551 |
17 | Database | [mysql] DB->Text, Text->DB 변환 | hooni | 2003.04.23 | 12129 |
16 | Database | [oracle] SQL문 실행 방법 3가지 | hooni | 2013.12.19 | 12123 |
15 | Database | [mysql] 루트 암호 초기화 | hooni | 2013.04.23 | 11044 |
14 | Database | [sql] 쿼리로 문자열 검색해서 일괄 치환하기 | hooni | 2014.02.13 | 9970 |
13 | Database | [mysql] 쿼리 실행시 ERROR 1366 (HY000) : incorrect string value : for column 3 | hooni | 2017.03.30 | 8782 |
12 | Database | [sql] 한눈에 보이는 Join | hooni | 2014.02.19 | 8463 |