20210107_ Python 입문5, 함수,*args,**kwargs, parameter hint, lambda

3 분 소요

Python 입문 05


Python 함수 정의 및 lambda(람다) 사용


1. 함수

  반복적, 중복 프로그래밍을 피할수 있음

1) 함수 정의(선언) 방법

  • 구조
def 함수명(매개변수parameter):
    code    


  • 리턴값이 없는 함수
def hello(world):
    print("hello", world)

hello("python!")
# world 만 붙여 출력만 하는 함수라서 값이 지정 되어 있지 않아 type()로 데이터 형식 확인 안됨


  • 리턴값이 있는 함수
def hello_return(world):
    v = "hello" + str(world)
    return v

print(hello_return("python!!!"))
print(type(hello_return("python!!!")))
# 리턴 값이 할당이 되어서 type()로 데이터 형식 확인 가능


  • 다중 리턴 함수

  여러 리턴값들을 가지는 함수

def func_mul(x):
    y1 = x * 100
    y2 = x * 200
    y3 = x * 300
    return y1, y2, y3
# parmeter x하나 넣으면 리턴 3개 값이 나옴
val1, val2, val3 = func_mul(100)
# 변수 3개에 한개의 라인으로 선언
print(type(val1), val1, val2, val3)
# type() 확인하면 그대로 int 나옴


  • 다중 리턴 함수 + 데이터 타입 반환

  다중 리턴 함수에서 리턴 값들을 다른 타입의 데이터로 반환하게 하는 것

# list 형 (for반복문 연계)
def func_mu2(x):
    y1 = x * 100
    y2 = x * 200
    y3 = x * 300
    return [y1, y2, y3] # [ ] 사용

# tuple 형 (for반복문 연계)
def func_mu3(x):
    y1 = x * 100
    y2 = x * 200
    y3 = x * 300
    return (y1, y2, y3) # ( ) 사용


2) *args (arguments), **kwargs(keyword arguments) 사용

  기본 매개변수(parameter)가 필수 사항이면 *args, **kwargs 는 선택사항으로 두고 매개변수(parameter)가 몇개 올지 모르는 상황에서 사용

  단, *args 는 리턴 시키거나, print 전까진 tuple 형태, **kwargs는 dict 형태로 리턴 됨, 그리고 그냥 print()형태 함수로 하면 표현은 tuple, dict 형태로 나오는데 type은 none type임

  • *args 기본 구조
def args_func(*args):  
    print(type(args))  
    
args_func('kim')
# 선언만 되어도 기본 튜플 타입

def args_func(*args):  
    return args

print(type(args_func('kim')))
# 리턴 해도 기본 튜플 타입

def args_func(*args):  
    print(args)

args_func('kim')
print(type(args_func('kim'))
# 출력은 튜플 형태로 보이나, 출력자체는 none type


  • **kwargs 기본 구조
def kwargs_func(**kwargs):
    print(kwargs)

kwargs_func(name1="kim", name2="park", name3="lee")
# dict 형태로 출력 


  • *args, **kwargs + for 문 활용
def args_func(*args):  
    for t in args:
        print(t)

args_func('kim', 'Park', 'Lee')
# 차례 대로 kim , park , lee 출력

def kwargs_func1(**kwargs):
    for i, v in kwargs.items():
        print(i, v)

kwargs_func1(name1="kim", name2="park", name3="lee")
# dict형태로 만들어진 key - value 묶음으로 차례대로 출력


3) enumerate 함수 활용

  입력으로 받은 데이터(순서있는 데이터 : str,tuple,list )를 인덱스 값을 포함하는 enumerate 객체로 리턴

  enumerate 객체 : (인덱스 , 값)

  • 구조
def args_func(*args):  
    for i, v in enumerate(args): # 인덱스 뽑는 거니까 i, v 두개
        print(i, v)

args_func('kim', 'Park', 'Lee')
# 출력 : 0 Kim , 1 Park , 2 Lee 차례대로 하나씩


  • enumerate + range 활용
def args_func(*args):  
    for i, v in enumerate(range(10)):
        print(i, v)

args_func('kim')
# 뭘 넣든 그냥 0~9 인덱스 와 0~9 값이 묶여 객체로 리턴


4) 중첩함수(클로저)

  클로저 형태로 하면 변수의 선언 줄이고 메모리 관리 효율적

def func(num):
    def func_in_func(num): # 1. 내부 함수 선언만 한 상태
        print(">>>", num)         # 4. 내부 함수에 들어온 20000을 넣어 출력
    print("in func")       # 2. 외부 함수에 값 들어오고 in func 출력
    func_in_func(num + 10000) # 3. 내부 함수에 외부함수에 넣은 값을 +10000 해서 넣고

func(10000)  # 20000       

5) Parameter Hint (파라미터 힌트)

  • ctrl + shift + space : 힌트 보기

  • 구조

def func_mul(x : int) -> list: # 명시적으로 입력값 int -> 출력값 list 라고 알려 줄 수 있다.
    y1 = x * 100
    return [y1]

print(func_mul(5))


2. lambda 식 (람다 식)

  메모리 절약, 가독성 향상, 코드 간결

  • 함수의 객체 생성(선언만 하더라도 print, type에서 확인 가능) -> 메모리 할당

  • 람다 즉시 실행 -> 메모리 초기화

1) 구조

lambda_1 = lambda num: num * 10  
# lambda num 부분이 입력 부분이고 : num * 10 이 출력 부분

print(lambda_mul_10(10))            
# 단순히 코드의 길이를 줄이는게 아니고 빠르게 처리하는데 의미가 있음
print(type(lambda_mul_10(10))) 
# type 확인해 보면 int로 바로 가져옴 중간에 함수 fuction으로 메모리 할당 없이 가능


  • 매개변수를 함수, lambda로 받는 경우
def func_final(x, y, func):     # 매개변수(파라미터)로 함수를 받을 수도 있음
    print(x * y * func(10))

func_final(10, 10, lambda_mul_10) # 기존의 함수에 10이 들어가서 현재 함수에서 계산됨

print(func_final(10, 10, lambda x : x * 1000)) 
# 그런데 그냥 람다 형식도 된다.함수 선언 없이 빠르고 메모리 할당도 없이 좋다.