[Python] Function Parameters 1

김가람휘·2022년 1월 28일
1

Python

목록 보기
3/14
post-custom-banner

Function Parameters

1. Function Parameters

앞서 함수는 input parameter를 받아서 return 값을 output으로 리턴한다고 배웠습니다. 그리고 함수를 호출할때 parameter를 함수에 건내주어서(pass) 호출 한다고 배웠습니다.
함수의 parameter에는 여러 형태가 있는데요, 하나씩 보도록 하겠습니다.
먼저 가장 기본적인 형태는 순서대로 값이 parameter로 함수에 전해지는 경우입니다.

2. Keyword Arguments

하지만 위의 경우 처럼 순서에 맞추어서 parameter 값을 전해주지 않을수 있는 방법도 있습니다.
순서 대신에 parameter 이름으로 맞추어서 값을 전해줄 수 있으며, 이를 keyword argments 라고 합니다.
Keyword arguments 방식으로 parameter 값을 전해주면 실제 parameter 순서가 바뀌어도 괜찮습니다.

순서가 바뀌어도 괜찮다는 점 말고도 또 가독성도 높아진다는 점도 있습니다.
parameter 순서에 맞추어 값을 함수에 넘기는 경우, 실수로 값이 바뀌어도 알기가 힘들다는 단점이 있습니다.
그에 비해 keyword arguments는 parameter 이름에 맞추어서 값을 함수에 넘기기 때문에 실수로 값이 바뀔 확률이 상대적으로 적다고 할 수 있습니다.
또한 코드를 읽는 사람도 어떠한 값을 넘기는건지 명확하게 알 수 있기 때문에 가독성도 높아진다고 할 수 있습니다.

3. Mixing positional arguments and keyword arguments

순서를 맞추어서 parameter 값을 전해주는 positional arguments와 keyword arguments를 혼용하여 사용하는것도 가능합니다.

다만, 여기서 중요한것은 keyword arguments 는 순서가 바뀌어도 상관 없지만 positional arguments 부분은 순서를 지켜줘야 한다는 것입니다.

예를 들어, 아래 코드처럼 함수를 호출하면 error가 납니다. 에러가 나는 이유는 keyword argument가 positional argument 보다 더 앞으로 위치되어 함수가 호출되었기 때문입니다.
Positional arguments는 순서를 지켜주어야 하는데 순서가 틀렸기 때문에 에러가 나는것입니다.

def love_you(my_name, your_name): 
   print(f"{my_name} loves {your_name}") 
   
   love_you(your_name = "아이유", "정우성")

> Traceback (most recent call last):
    File "python", line 1
SyntaxError: positional argument follows keyword argument

4. Parameter Default Value

함수의 parameter에 default 값을 정의해 줄 수 도 있습니다.
Default 값이 정의된 paramter는 함수가 호출될때 값이 넘겨지 않아도 괜찮습니다.
값이 넘겨지 않은 경우 default 값이 자동으로 넘겨지게 됩니다.

다만, 조심해야 할점은 default 값이 정의된 parameter가 default 값이 정의 되지 않은 parameter보다 먼저 위치해 있으면 안된다는 점입니다.
만일 default value parameter를 non-default value parameter 앞에 선언하면 syntax error가 납니다.

def love_you(my_name = "정우성", your_name): 
    print(f"{my_name} loves {your_name}") 
   
   love_you(your_name = "아이유", "정우성")
   
> Traceback (most recent call last):   
    File "python", line 1 
SyntaxError: non-default argument follows default argument

5. Variable length Arguments (가변 인수)

임의의 개수의 인자를 받는 함수를 가리켜 가변 인자를 사용한다고 표현한다.

def f(x, *args)
	...
f(1, 2, 3, 4, 5)
def f(x, *args)
  # x -> 1
  # args -> (2, 3, 4, 5) 
  # 추가적인 인자를 튜플로 전달한다.

6. Variable length keyword Arguments (가변 키워드 인수)

임의의 개수의 키워드 인자를 받는 함수를 가리켜 키워드 가변 인자를 사용한다고 표현한다.

def f(x, y, **kwargs):
	...
f(2, 3, flag=True, mode='fast', header='debug')
def f(x, y, **kwargs):
  # x -> 2 
  # y -> 3
  # kwargs -> {'flag':True, 'mode':'fast', 'header':'debug'}
  # 추가적인 키워드를 딕셔너리로 전달한다.

두 가지를 혼합한 함수는 임의의 개수의 가변 인자와 키워드 없는 인자들을 받을 수 있다.

def f(*args, **kwargs):
    ...
f(2, 3, flag=True, mode='fast', header='debug')
def f(*args, **kwargs):
    # args = (2, 3)
    # kwargs -> { 'flag': True, 'mode': 'fast', 'header': 'debug' }

튜플을 가변 인자로 확장하고 딕셔너리를 키워드 인자로 확장할 수 있다.

numbers = (2,3,4)
f(1, *numbers)      # f(1,2,3,4)와 같음


options = {
    'color' : 'red',
    'delimiter' : ',',
    'width' : 400
}
f(data, **options)
# f(data, color='red', delimiter=',', width=400)와 같음
post-custom-banner

0개의 댓글