Develop				
			
										2019.11.22 03:30				
				[python] 파라미터 앞에 *, ** 의 의미? (*args, **kwargs)
																																			조회 수 3928										댓글 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
| 번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 | 
|---|---|---|---|---|---|
| 1141 | Develop | [php] 3 Ways to Detect Mobile or Desktop in PHP   | hooni | 2020.01.28 | 7974 | 
| 1140 | Develop | 자주 쓰는 Docker 명령어 alias | hooni | 2020.01.10 | 292491 | 
| 1139 | Develop | [python][django] request.cookie 읽어오기 ㅋㅋㅋ (쓰기) | hooni | 2019.12.06 | 3863 | 
| 1138 | System/OS | SSH Passwordless Login Using SSH Keygen in 5 Easy Steps   | hooni | 2019.11.22 | 4639 | 
| 1137 | System/OS | [virtualbox] VirtualBox에 Ubuntu 설치하기   | hooni | 2019.11.22 | 2759 | 
| 1136 | Database | [mysql] MySQL 데이터베이스 추가 및 사용자 추가 | hooni | 2019.11.22 | 3205 | 
| 1135 | Database | [oracle] Oracle 사용자 추가 절차 | hooni | 2019.11.22 | 2778 | 
| 1134 | Database | [mysql] MySQL 백업 및 복구 | hooni | 2019.11.22 | 3023 | 
| 1133 | Database | [mysql] MySql DB/테이블 사이즈 확인을 위한 쿼리 | hooni | 2019.11.22 | 2757 | 
| 1132 | Database | SQL JOIN 정리 (Inner Join & Outer Join)   | hooni | 2019.11.22 | 4063 | 
| » | Develop | [python] 파라미터 앞에 *, ** 의 의미? (*args, **kwargs) | hooni | 2019.11.22 | 3928 | 
| 1130 | Develop | 링크들 보고 지울 내용   | hooni | 2019.11.21 | 0 | 
 SQL JOIN 정리 (Inner Join & Outer Join)
							SQL JOIN 정리 (Inner Join & Outer Join)