Week1 - Day 3 Review


오늘 하루 한 것

  • 강의듣기
    • Ai Math 5강까지
  • 과제
    • Gradient Descent 완료
  • 정리
    • 경사하강법 완료
    • python 5-1까지 정리 완료

피어세션

  • numpy dtype float32 최대 최소값에 관해서
    • int형은 단순 비트계산이지만 float형은 부동소수점형으로 지수비트와 유효자리비트로 나뉘어있기 때문에
    • int형 -> 정확함
    • float형 -> 자세히보면 잘라먹음

내일 할것

  • 역전파, 통계, CNN, RNN 정리
  • 심화과제 2, 3

주말에 할 것

  • 추가 정리
    • 정규식
    • pickles
    • __init__.py, __main__.py
    • numpy, pandas 정리

느낀점

  • 아직도 할게 많다… 정리 빨리 끝내고싶다

부스트 캠프 ai tech 1주 3일차 Python Basic for AI (7)


11. Object Oriented Programming (객체 지향적 프로그래밍, OOP)

  • 객체(Object)란?
    프로그램에서 사용되는 데이터 또는 식별자에 의해 참조되는 공간, 독립된 단위를 의미한다
  • OOP는 여러개의 독립된 객체들의 모임으로 프로그램을 구성하는것을 이야기한다

11.1 Object in Python

  • Python에서의 객체는 class로 선언이 가능하다

  • class는 속성(Attribute)와 명령어(Method)을 가지고 있다

    • Attribute
      해당 class가 가지고 있는 특별한 변수를 말한다. 이 변수는 다른 객체가 될 수도 있다. __init__(self) 메서드로 속성을 미리 설계할 수 있다
    • Method
      해당 class가 내장하고 있는 함수들을 지칭한다. 메서드는 class 안에 기존 함수와 같은 방식으로 정의가 가능하나, 반드시 self를 추가해야 메서드로 인정된다. 또한 python에는 특별한 메서드 들이 존재한다
  • class의 이름 선언과 함께 __init__메서드에 parameter 값들을 입력하면 객체를 생성 할 수 있다

  • class_name.method_name()과 같은 형식으로 객체의 메서드를 호출 할 수 있다

  • 예시 축구선수

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
class SoccerPlayer(object):
def __init__(self, name, position, back_number):
self.name = name
self.position = position
self.back_number = back_number

def change_back_number(self, new_number):
print("선수의 등번호를 변경합니다 : From %d to %d" % (self.back_number, new_number))
self.back_number = new_number

def kick(self):
pass

def heading(self):
pass

def moving(self):
pass

jinhyun = SoccerPlayer("Jinhyun", "MF", 10)
print("현재 선수의 등번호는 :", jinhyun.back_number)
jinhyun.change_back_number(5)
print("현재 선수의 등번호는 :", jinhyun.back_number)
==================================================
output:
현재 선수의 등번호는 : 10
선수의 등번호를 변경합니다 : From 10 to 5
현재 선수의 등번호는 : 5

11.1.1 Special method

  • class에는 __init__ 과 같이 특정한 일을 전담하는 정해진 메서드들이 존재하고 이것들을 Special method라고 부른다
  • class 내부에 Special method를 정의하면 객체간의 operator 연산 등 여러가지를 할 수 있다.
  • 자세한 내용은 링크로 남기고 생략한다.
  • 여러가지 스페셜 메서드

11.2 OOP의 특징

  • Visibility 가시성
    • 객체의 정보를 볼수 있는 레벨을 조절한다
    • 유저에게 필요한 부분은 보여주고(추상화), 노출할 필요가 없는 정보들은 숨긴다(캡슐화)
    • __ 를 속성이나 메서드 앞에 붙여서 객체 외부에서 접근할 수 없게 한다
    • 결론 : docstring 잘 쓰는게 중요하다
  • Inheritance 상속
    • 부모클래스로부터 속성과 Method를 물려받은 자식클래스를 생성 하는 것을 말한다
    • super를 통해 부모클래스의 메서드를 호출 할 수 있다
    • 코드의 재사용이 목적이다
  • polymorphism 다형성
    • 같은 이름의 메서드의 내부로직을 다르게 사용할 수 있다.
    • 자식클래스에서 메서드를 재정의(overiding)하여 새로 맞춰서 사용이 가능하다
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class TeamAPlayer(SoccerPlayer):
def __init__(self, regular):
super().__init__(name, position, back_number)
self.regular = regular

def is_regular(self):
print(self.name, '선수는 주전', '입니다' if self.regular else '이 아닙니다')

def change_back_number(self, new_number):
print(f"팀 A {self.name}선수의 등번호를 변경합니다")
super().change_back_number()
self.back_number = new_number

jinhyun = TeamAPlayer("Jinhyun", "MF", 10, False)
jinhyun.is_regular()
jinhyun.change_back_number(5)
=============================
output:
Jinhyun 선수는 주전 이 아닙니다
팀 A Jinhyun선수의 등번호를 변경합니다
선수의 등번호를 변경합니다 : From 10 to 5

참고 자료

객체 지향 프로그래밍 - wikipedia

부스트 캠프 ai tech 1주 2일차 Python Basic for AI (6)


10. Pythonic Code

  • Python 스타일의 효율적인 코딩기법
  • 사용하면 코드를 간결하고 이쁘게 작성할 수 있다. 그리고 잘하는 사람처럼 보인다
    • 그러니 모두 잘 익히고 사용하자

10.1 List comprehension

  • 기존의 list를 사용하여 간단한 list를 만드는 기법
  • for 문 + list.append 보다 속도가 빠르다
  • 조건문과 함께 더 다양한 list를 표현 가능하다
    1
    2
    3
    4
    5
    6
    # 기존 방법
    a = []
    for i in range(10):
    a.append(i)
    # list comprehension
    a = [i for i in range(10)]

10.2 enumerate & zip

  • enumerate
    • for 문에서 iterable object의 element를 추출할 때 인덱스 번호와 함께 추출
      1
      2
      3
      4
      5
      for i, x in enumerate('apple'):
      print(i, x) # 0 a, 1 p, ... , 4 e

      list(enumerate('apple'))
      output = [(0, 'a'), (1, 'p'), (2, 'p'), (3, 'l'), (4, 'e')]
  • zip
    • 여러개의 list값을 병렬적으로 추출해서 하나의 list로 재결합 시킨다.
      1
      2
      3
      4
      5
      a = (1, 2, 3)
      b = (4, 5, 6)
      print(list(zip(a, b)))
      ######################
      [(1, 4), (2, 5), (3, 6)]

10.3 map & lambda & reduce

  • map
    • iterable object의 element에 각각 특정한 함수를 적용할 수 있는 함수
    • 아래의 lambda와 병행하여 자주, 많이 쓰인다
    • 실행시점의 값을 생성해서 메모리를 효율적으로 사용한다
      1
      2
      3
      4
      5
      6
      7
      def function(x):
      return x**2

      a = [1, 2, 3, 4, 5]
      print(list(map(function, a)))
      #############################
      output => [1, 4, 9, 16, 25]
  • lambda
    • 함수를 따로 정의할 필요 없이 사용할 수 있는 익명 함수
    • PEP8에서 권장하지는 않지만 아직도 많이쓰고 스스로도 많이 쓰고있다
      • 어려운 문법, 테스트하기 힘듬, docstring 지원안함, 코드해석이 어려움 등등의 문제가 있다
    • 간단한 명령문인 경우 따로 정의하지 않고 lambda를 사용하는 편이다
      1
      2
      3
      4
      a = [1, 2, 3, 4, 5]
      print(list(map(lambda x: x**2, a)))
      #############################
      output => [1, 4, 9, 16, 25]
  • reduce
    • map과 비슷한 동작으로 list에 똑같은 함수를 적용해서 합쳐나간다
    • 2년 넘게 공부하면서 한번도 쓴적이 없다
    • python3 버전에서 lambda와 같이 사용을 권장하지 않는다
      1
      2
      from functools import reduce
      print(reduce(lambda x, y: x+y, [1, 2, 3, 4, 5]))

reduce 이미지

10.4 iterable object

  • 시퀸스형 자료형에서 데이터를 순서대로 추출하는 object
  • object 내부적으로 __iter__와 __next__라는 함수(메서드)가 존재한다
  • .iter() 와 .next() 함수로 iterable 객체를 iterator object로 사용이 가능하다
  • 아래의 generator와 같이 사용하면 정말 강력한 성능을 보이게 된다
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    cities = ["Seoul", "Busan", "Jeju"] 
    iter_obj = iter(cities)
    print(next(iter_obj))
    print(next(iter_obj))
    print(next(iter_obj))
    next(iter_obj)
    ==============
    output:
    Seoul
    Busan
    Jeju
    Error 발생 더이상 출력할 수 있는 원소가 없음

10.5 generator

  • iterable object를 특수한 형태로 사용해주는 함수

  • object 내부의 element가 호출되는 시점에 값을 메모리에 반환한다

    • yield를 사용해서 한번에 하나의 element만 반환함
      • 이 것이 궁금하다면 python 코루틴 관련해서 찾아보는것이 좋다
  • 일반적인 iterator 보다 generator가 훨씬더 적은 메모리를 사용한다

  • 먼 훗날에 나올 Dataset이 generator를 이용한 object이다

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    def my_gen():
    n = 1
    print('This is printed first')
    # Generator function contains yield statements
    yield n

    n += 1
    print('This is printed second')
    yield n

    n += 1
    print('This is printed at last')
    yield n


    # Using for loop
    for item in my_gen():
    print(item)

    =====================
    output:
    This is printed first
    1
    This is printed second
    2
    This is printed at last
    3

    예제출처

  • generator도 list comprehension과 유사한 형태로 표현이 가능하다

  • [] 대신 ()로 표현한다.

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    gen_ex = (n*n for n in range(500)) 
    print(next(gen_ex)) # 0 1 4 ....
    ```

    ### 10.6 function passing arguments
    * 함수에 입력되는 Argument는 아래와 같이 다양한 형태를 가진다
    * Keyword arguments
    * 함수에 입력되는 parameter의 변수명을 같이 입력하여 순서에 상관없이 parameter를 지정 해 줄 수 있다
    ```python
    def function(a, b):
    return a*2 + b

    print(function(3, 5))
    print(function(b=5, a=3))
    =========================
    output:
    11
    11
    • Default arguments

      • parameter의 기본값을 사용한다
      • 따로 argument가 입력되지 않을 경우 기본값으로 출력한다
        1
        2
        3
        4
        5
        6
        7
        8
        9
        10
        11
        12
        13
        14
        15
        16
        17
        18
        19
        20
        21
        22
        23
        24
        25
        26
        27
        28
        def function(a, b=0):
        return a*2 + b

        print(function(3, 1))
        print(function(3))

        ==================
        output:
        7
        6
        ```

        * Variable-length arguments(가변인자)
        * 개수가 특정되지 않은 변수를 함수의 parameter로 사용하는 방법
        * Asterist * 기호를 사용하여 argument를 나타낸다
        * 입력된 값은 Tuple로 사용할 수 있다
        * 함수에서 단 하나 존재하고, 뒤에 일반적인 argument가 존재할 수 없다

        ```python
        def asterisk_test(a, b, *args):
        print(args)
        return a+b+sum(args)
        print(asterisk_test(1, 2, 3, 4, 5))

        ===================================
        output:
        (3, 4, 5) 튜플의 형태로 존재한다
        15
    • Keyword Variable-length arguments(키워드 가변인자)

      • Parameter의 이름을 따로 지정하지않고 입력하는 방법
      • Asterisk 두개 (**) 를 사용하여 함수의 parameter를 표시한다
      • 입력된 값은 dict type으로 사용할수 있다
      • 함수에서 단 하나 존재하고 뒤에 다른 argument가 존재할 수 없다
1
2
3
4
5
6
7
8
def asterisk_test(a, b, **kargs):
print(kargs)
return a+b+sum(kargs.values())
print(asterisk_test(1, 2, three=3, four=4, five=5))
===================================================
output:
{'three': 3, 'four': 4, 'five': 5}
15

10.7 Asterisk

  • Asterisk는 위의 가변인자와 곱하기 연산자 이외의 기능이 존재한다
  • list, tuple 등의 자료형 변수 앞에 *를 붙여서 unpacking 할 수 있다
  • dict type의 경우 **를 붙여서 키워드 가변인자처럼 출력이 가능하다
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    a = [1, 2, 3, 4]
    print(a)
    print(*a)
    b = {'one':1, 'two':2, 'three':3}
    print(*b)
    print(asterisk_test(1, 2, **b))
    ===============================
    output:
    [1, 2, 3, 4]
    1 2 3 4
    one two three
    {'one': 1, 'two': 2, 'three': 3}
    9

부스트 캠프 ai tech 1주 2일차 Python Basic for AI (5)


9. 데이터 구조

  • Stack & Queue
  • Tuple & Set
  • Dictionary
  • Collection

9.1 Stack & Queue

  • Stack
    • 나중에 넣은 데이터를 먼저 반환하도록 설계된 데이터 구조
    • LIFO (Last in First Out)
    • 입력을 Push, 출력을 Pop이라고 한다
    • python의 list는 기본적으로 Stack의 구조를 가진다
  • Queue
    • 먼저 넣은 데이터가 먼저 반환하도록 설계된 데이터 구조
    • FIFO (First in First Out)
    • 입력은 Push, 출력은 get 이라고 한다
    • 보통 python의 Dequeue를 사용한다.
  • 정해진 크기를 넘어갈 경우 overflow, element가 없는데 반환을 시킬경우 underflow라고 한다.

9.2 Tuple & Set

  • Tuple
    • 값의 변경이 불가능한 리스트
    • index로 접근해서 값을 수정하는것을 막는다
    • 정의 할 때 ( )를 사용한다
    • 리스트와 동일하게 (+, *)연산, Indexing, Slicing을 사용한다
    • 사용자의 실수에 의한 에러를 사전에 방지하기 위해 변경할 필요가 없는 데이터를 저장할 때 사용한다
1
2
3
t = (1, ) # 값이 1개인 Tuple은 반드시 ,를 붙여야 함
t + t # (1, 1)
t[0] = 2 # Error 발생함
  • Set
    • 값을 순서없이 저장, 중복을 허용하지 않는 자료형(확인필요)
    • set( )을 통하여 객체를 생성한다
    • set을 이용하여 다양한 집합연산이 가능하다
      1
      2
      3
      4
      5
      6
      7
      8
      s1 = set([1, 2, 3, 4, 5])
      s2 = set([1, 3, 5, 7, 9])
      s1.union(s2) # (1, 2, 3, 4, 5, 7, 9) 합집합
      s1 | s2 # (1, 2, 3, 4, 5, 7, 9) 합집합
      s1.intersection(s2) # (1, 3, 5) 교집합
      s1 & s2 # (1, 3, 5) 교집합
      s1.difference(s2) # (2, 4) 차집합
      s1 - s2 # (2, 4) 차집합

9.3 Dictionary

  • 데이터를 저장 할 때 구분지을수 있는 값(Key)를 함께 저장
  • Hash 구조
  • Key값을 활용하여 Value를 관리한다.
  • dict( )나 { }로 객체를 생성한다
1
2
3
4
5
6
7
8
9
10
number_dic = {'one': 1, 'two': 2, 'three': 3}
number_dic['one'] # 1, Key 값으로 value 출력 가능
country_code.items() # 데이터 출력
# dict_items([('one', 1), ('two', 2), ('three', 3)])
number_dic.keys() # key만 출력
# dict_keys(['one', 'two', 'three'])
number_dic.values() # value만 출력
# dict_values([1, 2, 3])
number_dic.get(1) # None, 아닐경우 None
number_dic.get('one') # 1, key가 존재할 경우 values 값을 return

9.4 Collections

  • Python Built-in 확장 모듈

  • 편의성, 실행 효율 등을 사용자에게 제공함

  • 자주 사용되는 deque, difaultdict, Counter에 대해서만 다룰것이다

  • deque

    • Stack과 Queue의 기능을 모두 지원하는 데이터 구조
    • List에 비해 효율적인 저장방식을 지원한다
      • popleft()등 삽입 삭제에 매우 효율적임
    • Linked List의 특성(rotate, reverse)을 지원한다
    • 기존 list 형태의 함수를 모두 지원함
      1
      2
      3
      4
      5
      from collections import deque
      q = deque()
      q.append(a) # [a]
      q.appendleft(b) # [b, a]
      q.popleft() # [a]
  • defaultdict

    • Dict type값에 기본값을 지정해서 key가 존재하지 않아도 기본값으로 찾아지는 기능을 가지고 있다
    • defaultdict(datatype) 으로 기본값의 자료형을 정하면서 dict객체를 생성할 수 있다
      1
      2
      3
      4
      from collections import defaultdict
      dic = defaultdict(int)
      dic['a'] += 1 # {'a': 1}
      dic['b'] -= 1 # {'a': 1, 'b': -1}
  • Counter

    • 시퀸스 type의 data element들의 갯수를 dict형태로 변환
      1
      2
      3
      from collections import Counter
      c = Counter([1, 3, 5, 3, 2, 4, 3])
      # Counter({1: 1, 3: 3, 5: 1, 2: 1, 4: 1})

부스트 캠프 ai tech 1주 2일차 Python Basic for AI (4)


8. 문자열(string)

  • char들이 저장되어있는 시퀸스 자료형
  • 기본적으로 list와 같은 형태로 데이터를 처리한다
    • Indexing, Slicing, +, * 연산은 리스트와 동일하게 수행한다

8.1 자주 사용하는 문자열 함수

함수명 기능
len(a) 문자열의 문자 개수를 반환
a.upper() 대문자로 변환
a.lower() 소문자로 변환
a.capitalize() 첫 문자를 대문자로 변환
a.strip(input)
a.rstrip(input)
a.lstrip(input)
좌우/우/좌 input을 없앰
a.split(input) input 기준으로 문자열을 나눠서 리스트로 반환
a.isdigit()
a.islower()
a.isupper()
문자열이 숫자/소문자/대문자인지 여부 반환
a.startswith(input)
a.endswith(input)
문자열이 input으로 시작/끝 나는 문자열 여부 반환
str.join(list) list의 원소들을 str로 연결해서 하나의 문자열로 나타낸다
단 list의 원소는 모두 문자열 type 이어야 한다

8.2 다양한표현

  • \ (백슬래쉬) : 특수하게 사용하는 문자열을 표현하기위해서 사용한다
    • 백슬래쉬를 표현하기 위해서는 \\ 두번 사용하면 된다.
  • \n : 줄바꿈을 의미하는 특수문자
  • \t : TAB
  • “””문자열””” : 줄바꿈도 자유롭게 입력 가능한 문자열 표현
  • r”문자열” : 특수문자를 무시하고 그대로 출력함
    1
    2
    print(r'이건 줄바꿈 기호입니다 \n')
    # output : 이건 줄바꿈 기호입니다 \n

부스트 캠프 ai tech 1주 2일차 Python Basic for AI (3)


6. Condition (조건문)

  • 조건에 따라 특정한 동작을 하게 하는 명령어
  • python 에서는 if, elif, else의 예약어를 사용한다
  • 조건을 나타내는 기준과 실행해야하는 명령으로 구성된다
  • 조건이 참일때만 실행한다
    1
    2
    3
    4
    5
    6
    7
    8
    if age <= 13:
    print('초등학생')
    elif age <= 16:
    print('중학생')
    elif age <= 19:
    print('고등학생')
    else:
    print('성인')
비교연산자 설명
x < y x가 y보다 작은지 검사
x > y x가 y보다 큰지 검사
x == y x와 y가 같은값인지 검사
x is y x와 y의 메모리 주소가 같은지 검사
x != y x와 y가 같은값인지 검사
x is not y x와 y의 메모리 주소가 같은지 검사
x >= y x가 y이상인지 검사
x <= y x가 y이하인지 검사
  • c언어에서는 0은 False, 1은 True를 나타내지만, python에서는 성립하지 않는다
  • 존재하면 참, 없으면 거짓으로 판단한다
  • and, or, not 논리키워드와도 같이 사용한다
    1
    2
    3
    if 1 # True
    if 0 # True
    if None # False

6.1 삼항연산자(Ternary operators)

  • 참과 거짓만 존재하는 결과를 한줄에 표현 할 수 있다.
    1
    2
    a = 1
    print('number' if isinstance(a, int) else 'not number')

    isinstance(var, datatype) -> boolean

    데이터의 타입을 판단하는 함수

7. 반복문

  • 정해진 동작을 반복적으로 수행하게 하는 명령문
  • for, while 명령 키워드가 존재한다

7.1 for 문

  • iterable 한 object의 원소의 갯수 만큼 반복시켜주는 반복문
  • range, enumerate등과 연계하여 사용이 가능하다
    1
    2
    3
    4
    5
    6
    for i in range(1, 10, 2):
    print(i) # 1, 3 ... 7 ,9
    for i in range(10, 1, -1):
    print(i) # 10, 9, ... , 2, 1
    for i, x in enumerate('apple'):
    print(i, x) # 0 a, 1 p, ... , 4 e

7.2 while 문

  • 조건을 만족하는 동안 반복적으로 명령을 수행한다
    1
    2
    3
    4
    5
    i = 0
    while i < 5:
    print(i)
    i += 1
    # output 0, 1, 2, 3, 4

7.3 반복문 제어

  • break : 특정 조건에서 가장 가까운 반복문을 종료한다
  • continue : 특정 조건에서 남은 명령을 skip 하고 다음 루프로 넘어간다
  • else : 반복조건이 만족하지 않은경우 반복 종료시 1회 수행한다.
    • break로 반복문에서 탈출할 경우에는 수행하지 않음

Week1 - Day 1&2 Review


오늘 하루 한 것

  • Day1
    • 팀원들과 아이스 브레이킹
    • 강의 듣기 (python 2-4까지)
    • 노션 회고록 Template 만들기
    • 과제
      • Basic Math
      • Text Processing 1
      • Text Processing 2
  • Day2
    • 강의듣기
      • python 강의 완료
      • Ai Math 경사하강법까지 완료
    • 과제
      • Gradient Descent 하는 중
      • 기본퀴즈 1~5강
    • python 3-2강 까지 정리

피어세션에서 한것

  • Day1
    • 피어세션 그라운드 룰 만들기
  • Day2
    • python 메모리 관리에 대한 질문
    • 구조체 메모리 점유에 대한 질문

내일 할것

  • 심화과제 끝내기
  • 과제과정, 결과 + 정규식에 대해서 정리해보자

느낀점

  • 어떻게 해야 남이보기 쉽게 설명할수 있을까? 정리하는데 시간이 오래걸린다.
  • 1일차 한 내용이 많아서 하루만에 정리하기 쉽지 않았다. 예전에도 한번 시도했지만 꾸준히 정리해야 할맛나는것 같다. 쌓이면 쌓일수록 답이없다…..
  • 매일 적당한 양을 공부하고, 정리할것
  • 알아도 정리하자!

부스트 캠프 ai tech 1주 2일차 Python Basic for AI (2)

1일차 배운내용 2일차에 정리하는중…


4. Function(함수)

  • 어떤 일을 수행하는 논리적인 코드 단위
  • parameter, indentation(들여쓰기), return 등으로 구성된다
  • argument : 함수를 호출할 때 입력되는 파라미터들을 말한다
1
2
3
4
5
def im_function(im_parameter): #함수의 정의와 파라미터
im_return = im_parameter # 수행 내용
return im_return # 리턴값

result = im_function(im_argument)
  • 함수에 return 값이 존재하지 않을경우 함수는 None을 리턴한다

4.1 지역변수 & 전역변수

  • 지역변수(local variable) : 함수 내에서만 사용되는 변수
  • 전역변수(global variable) : 프로그램 전체에서 사용하는 변수
    • global을 사용하여 함수내에서 정의 할 수 있다.
1
2
3
4
5
6
def function(x):
global y
return x + y

y = 5
print(function(6)) # 11

4.2 재귀함수(recursive Function)

  • 자기자신을 호출하는 함수
  • 종료조건이 존재하여 종료조건을 만족시킬때 까지 스스로를 호출한다
  • python에서는 recursivelimit가 걸려있어서 따로 sys 모듈을 통해 한도를 늘려놓아야 한다.
  • 개인적으로 별로 안이용하고 싶음

4.3 Function type hints & Docstring

  • Function type hints
    python에서는 dynamic typinig 형식으로 작성하기 때문에 별도로 자료형을 적어두지 않기 때문에 처음 함수를 사용하는 사용자가 interface를 알기 어렵다는 단점이 있다.
    이를 해결하기 위해 type hints 기능을 제공한다.
    • parameter와 return의 type을 알려주는 type hints
1
2
def this_is_function(var_name: var_type) -> return_type:
pass
  • Docstring
    함수에 대한 상세 스펙(필요한 parameter, return, 수행하는 일 등등)을 사전에 작성한다.
    세개의 따옴표로 함수명 아래에 표시한다
    1
    2
    3
    4
    5
    6
    7
    8
    9
    def function(x):
    """
    this is docstring
    return parameter
    x : int
    =======
    return int
    """
    return x

4.4 python 가이드 라인

  • 함수는 가능하면 짧게 작성한다
  • 함수이름에 역할, 의도를 명확하게 나타낼 수 있도록 한다
  • 하나의 함수에는 유사한 역할을 하는 코드만 포함한다
  • parameter로 받은 값 자체를 바꾸지 않는다
  • 공통 코드나 복잡한 수식은 함수로 나타낸다
  • PEP8 참고해보자

5. input & print & fommatting

  • input 함수는 콘솔창에서 문자열을 입력받는 함수이다(string 형태로 받아옴)
  • print 함수는 입력받은 값을 문자열으로 출력한다
  • , 를 사용할 경우 print문이 공백을 사이에 두고 연결된다
    1
    2
    3
    print("name :")
    name = input() # input -> 규범
    print("Hello", name) # Hello 규범
  • formatting을 통해서 출력양식의 형식을 지정할 수 있다.
type 설명
%s 문자열(string)
%c 문자 1개(character)
%d 정수 (int 형)
%f 부동소수(float 형)
%o 8진수
%x 16진수
%% % 문자 자체
  • %n.m(datatype)

    • string : n개의 문자로 맞춘다(공백으로 채운다). m 자리수까지만 나타낸다(혼용 불가)
    • int : n개의 문자로 맞춘다(공백으로 채운다). m 은 사용불가
    • float : n개의 문자로 맞춘다(공백으로 채운다). 소숫점 m자리까지 나타낸다
  • Python 3.6 이후의 PEP8에 근거한 formatting

    1
    2
    3
    name = Jone
    age = 20
    print(f'Hello, {name}. I am {age}.') # Hello, Jone. I am 20.
  • 예전방식

    1
    2
    print('%s %s' % ('one', 'two')) # one two
    print('%d %d'.format(1, 1)) # one two

부스트 캠프 ai tech 1주 1일차 Python Basic for AI (1)


1. Python의 특징

  • 독립적인 플랫폼
    운영체제에 상관없이 작동하는 언어이다.
  • 인터프리터 언어
    별도의 컴파일링 없이 컴퓨터가 바로 처리할 수 있는 언어이다. 속도는 컴파일러 언어에 비해서 느리지만 메모리가 적게 필요하다.
  • 객체지향적
    실행 순서가 아닌 단위 모듈 중심으로 프로그램이 작성된다.
  • Dynamic Typing 언어
    프로그램이 실행하는 시점에 프로그램이 사용해야하는 데이터 타입이 결정된다.

2. 변수

  • 데이터를 저장하기 위한 메모리 공간
    변수가 정의되면 변수는 메모리 주소를 할당 받고, 그 메모리 위치에 값을 저장한다. 그 외에 python에서 어떻게 변수를 할당받고 메모리를 관리하는지 알고싶으면 아래의 영상을 참고하는걸 추천한다.
  • 기본 자료형들은 +, -, *, %의 사칙연산이 가능 하다
  • Dynamic Typing을 지원하기 때문에 정의할 때에 자료형을 특정하지 않아도 된다.
    • 실행하는 시점에서 변수형을 확인하고 결정하기 때문에 타 언어보다 속도가 느리다.
    • 아래와 같이 자료형간 형 변환또한 가능하다.
1
2
3
4
5
a = 1 # int형으로 정의
int(a) # int() 로 형 변환 가능
str(a) # str로 재정의 이때의 값은 '5'
float(a) # float형으로 재정의 이때의 값은 '5.0'
bool(a) # boolean 형으로 재정이 이때의 값은 True

3. 리스트

  • 여러 데이터들을 묶어서 표현할 수 있는 자료형
  • python 에서는 리스트 내부에 여러가지 자료형이 동시에 존재할 수 있다.

1. List Indexing & Slicing

  • Indexing : 리스트에 있는 값들은 주소를 사용해 호출이 가능하다
  • index를 넣는 곳에 음수값을 넣어서 뒤에서부터 호출 할 수 있다.
  • len(object_name) : object의 길이를 반환한다
    1
    2
    3
    4
    5
    6
    color = ['red', 'blue', 'green']
    print(colors[0]) # red
    print(colors[-1]) # green
    print(len(colors)) # 3
    color[0] = 'Yellow' # ['Yellow', 'blue', 'green']

  • Slicing : list의 값들을 잘라서 부분적으로 표현할 수 있다.
  • index과 같이 음수값 통해 역순으로도 가능하다.
1
2
3
4
5
numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 0]
print(numbers[0:6]) # [1, 2, 3, 4, 5, 6] index 0번부터 6개
print(numbers[:]) # [1, 2, 3, ... , 7, 8, 9] 처음부터 끝까지
print(numbers[::2]) # [1, 3, 5, 7, 9] 2칸단위로 슬라이싱
print(numbers[-5::-1]) # [6, 5, 4, 3, 2, 1] 뒤에서 5번째부터 역순으로 슬라이싱

2. List 연산

  • + : 두 리스트를 합쳐준다
  • * : 리스트를 n회 반복해서 늘린다
    1
    2
    3
    4
    num1 = [1, 2, 3]
    num2 = [3, 4, 5]
    num1 + num2 # [1, 2, 3, 3, 4, 5]
    num1 * 2 # [1, 2, 3, 1, 2, 3]
  • list.append(element) : list에 element를 추가한다
  • list.extend(iterable) : list에 iterable의 원소들을 추가한다
  • list.insert(index, element) : list의 특정 index 위치에 element를 삽입한다
  • list.remove(element) : list의 특정 element를 삭제한다
1
2
3
4
5
num = [1, 2, 3]
num.append([4, 5]) # [1, 2, 3, [4, 5]]
num.extend([1, 2]) # [1, 2, 3, [4, 5], 1, 2]
num.insert(0, 'a') # ['a', 1, 2, 3, [4, 5], 1, 2]
num.remove(1) # ['a', 2, 3, [4, 5], 2]

3. 2-dim list

  • 행렬
  • 기존의 리스트와 비슷하지만, 복사할때 주의할점이 필요하다
    리스트를 복사할때 리스트 주소가 복사되기 때문에 내부의 리스트는 동일한 주소의 값을 가져 하나의 리스트를 변경하면 다른 리스트값도 변경됨
    • python 모듈중 copy의 deepcopy를 이용하여 복사
      1
      2
      3
      4
      mat = [[1, 2, 3], [4, 5, 6]]
      mat2 = mat
      mat[1][0] = 2 # [[2, 2, 3], [4, 5, 6]]
      mat2 # [[2, 2, 3], [4, 5, 6]]