• 검색 결과가 없습니다.

기능소개

문서에서 제대로 배워보자 (페이지 36-49)

세부 목차

5. 기능소개

5.1 Python 변수 만들기 및 화면 출력

• 변수명 만들기

- 변수명을 만들 때는 영어 소문자, 대문자, 숫자, _으로 구성하면 된다. 하지만 단 숫자로는 시작할 수 없다.

- Python은 대소문자를 구별한다.

- Python에서 사용되는 키워드 및 예약어는 사용이 불가하다.

- 변수명 예시

- 아래는 예약어 리스트다. 변수명으로 사용할 수 없다.

• 화면 출력하기 (print)

- Python에서 화면을 출력할 때 사용하는 함수는 print() 이다.

사용 가능한 변수명

a, a1, my_name, your_job, MyName, _private, __private_member 변수명이 될 수 없는 변수명

1abc, @file, fil@e, %x

False,None,True,and,as,assert,break,class,continue,def,del,elif,else,except,finally,for,from, global,if,import,in,is,

lambda

,nonlocal,not,or,pass,raise,return,try,while,with,yield

>>> print ("Hello Python") Hello Python

5. 기능소개

5.2 Sequence형 자료형(1/7)

• Sequence형 자료형이란?

- Sequence형 자료형은 여러 객체를 저장할 수 있는 순서를 갖는 연속된 자료형이다.

- 자료형의 종류는 아래와 같다.

- Sequence형 자료형에는 공통적인 연산이 있다.

➢ 인덱싱(indexing)

➢ 슬라이싱(slicing)

➢ 연결하기

➢ 반복하기

➢ 멤버십 테스트

➢ 길이정보

- Sequence형 자료형의 색인의 처음은 항상 0부터 시작한다. 아래는 문자열 예시다.

List, Tupe, String

a p p l e

0 1 2 3 4

문자열

Index

5. 기능소개

5.2 Python 자료형(튜플)(2/7)

• Python의 자료 구조는 다른 언어에 비해 단순하지만 매우 강력하다.

• 튜플, 리스트, 사전, 세트라는 자료 구조를 가지고 있다.

▪ 튜플(Tuple)

>>> tuple_tmp = 1, 2, 3

>>> tuple_tmp (1, 2, 3)

>>> tuple_tmp2 = (1, 2, 3), (4, 5)

>>> tuple_tmp2 ((1, 2, 3), (4, 5))

>>> tuple([1,2,3]) (1, 2, 3)

>>> tuple("Python String")

('P', 'y', 't', 'h', 'o', 'n', ' ', 'S', 't', 'r', 'i', 'n', 'g')

- 모든 Sequence형 자료형은 튜플 메서드를 사용하여 튜플로 변환할 수 있다.

- 1차원의 크기를 가지고 있는 변경이 불가능한 Sequence 자료형이다.

- 값 사이에 콤마(,)를 사용하여 튜플을 생성한다.

- 괄호 ( ) 를 사용하면 값을 묶어서 정의할 수 있다.

- 대괄호 [ ] 을 사용하면 튜플의 각 원소에 접근할 수 있다. Sequence 자료형의 색인의 시작은 0 이다.

>>> tuple_tmp[0]

1

>>> tuple_tmp[1]

2

문자열을 튜플로 변경

5. 기능소개

5.2 Python 자료형(튜플)(3/7)

▪ 튜플(Tuple)

>>> f = lambda x: x**2

>>> tuple_tmp3 = (f, [1,2], "python")

>>> tuple_tmp3

(<function <lambda> at 0x0000022D3455B9D8>, [1, 2], 'python')

>>> tuple_tmp1 = 1,2,3,4,5

>>> tuple_tmp1[1]

2

>>> tuple_tmp1[1] = 4

Traceback (most recent call last):

File "<stdin>", line 1, in <module>

TypeError: 'tuple' object does not support item assignment

- 튜플 안의 원소는 서로 다른 자료형 또는 객체를 담을 수 있다.

- 한번 생성된 튜플은 각 원소를 변경하는 것은 불가능하다.

f는 lambda 함수의 객체이며, [1,2]는 리스트 “python”은 문자열

처음 생성된 튜플의 원소의 값을 변경할 경우 Error가 발생

- 다른 Sequence형 자료형처럼 +, * 연산자를 사용하여 이어붙일 수도 반복할 수도 있다.

>>> tuple_tmp1 + (6, 7) (1, 2, 3, 4, 5, 6, 7)

>>> tuple_tmp1 * 3

(1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5)

* 객체는 복사되지 않으며, 그 객체에 대한 참조만 복사가 된다.

- 대입연산자를 사용하면 오른쪽에 있는 변수에서 값이 분리되는데 이를 unpacking이라고 한다.

>>> a, b, c, d, e = tuple_tmp1

>>> a 1

>>> a

tuple_tmp1의 원소의 값들이 a, b, c, d, e에 분리되어 저장

5. 기능소개

5.2 Python 자료형(리스트)(4/7)

▪ 리스트(list)

>>> list_tmp = [1, 2, 3, 4, 5]

>>> list_tmp [1, 2, 3, 4, 5]

- 튜플과 같은 Sequence형 자료형이나 크기나 원소 값을 변경할 수 있다.

- 대괄호 [ ] 나 list() 함수를 사용해서 생성할 수 있다.

- 튜플을 리스트 형식으로 list함수를 사용하면 변환 할 수 있다.

- 리스트도 튜플과 같이 +, * 연산자를 사용하여 이어붙일 수도 반복할 수도 있다.

>>> list_tmp + list_tmp [1, 2, 3, 4, 5, 1, 2, 3, 4, 5]

>>> list_tmp * 4

[1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5, 1, 2, 3, 4, 5]

>>> list_tmp2 = list(tuple_tmp1)

>>> list_tmp2 [1, 2, 3, 4, 5]

- 리스트의 메서드를 사용하면 원소 추가 및 삭제를 할 수 있다.

>>> list_tmp.append(6)

>>> list_tmp [1, 2, 3, 4, 5, 6]

>>> list_tmp.remove(2)

>>> list_tmp [1, 3, 4, 5, 6]

5. 기능소개

5.2 Python 자료형(사전)(5/7)

▪ 사전(Dicationary)

- 사전은 Python에서 중요한 자료형 중 하나입니다. Key-Value 형식으로 데이터를 저장한다.

- 중괄호 {} 나 dict() 함수를 사용해서 생성할 수 있다.

- 아래는 사전의 중요 내용이다.

▪ 키(Key) – 값(Value)을 원소라고 부른다.

▪ Dictionary은 중괄호 안에 쉼표로 구분된 원소를 넣어 생성한다.

▪ Dictionary_이름 = { 키_1 : 값_1, 키_N : 값_N}

▪ 매핑형에서는 key를 이용해 value에 접근한다.

▪ 내부적으로 해시 기법을 사용하기 때문에 검색 속도가 빠르다.

▪ key 값은 중복을 허용하지 않는다.

>>> contacts = {"철수" : "02-543-11111", "영희" : "02-543-2222"}

>>> contacts

{'철수': '02-543-11111', '영희': '02-543-2222'}

- 사전 생성 및 Key값을 사용해서 Value값을 호출하는 예시다.

>>> print (contacts['철수']) 02-543-11111

철수, 영희가 Key이고 각각의 전화번호가 Value값이다.

Key를 통해서 Value값에 빠르게 접근할 수 있다.

5. 기능소개

5.2 Python 자료형(집합)(6/7)

▪ 집합(Set)

- 집합은 여러 값을 순서 없이 그리고 중복 없이 모아 놓은 자료형이다.

- Python에서는 set과 frozenset 두 가지 집합 자료형을 제공한다.

- Set은 변경 가능한 집합, frozenset은 변경 불가능한 집합이다.

- 반복 가능한(Iterable) 객체로부터 집합을 만들 수 있지만 모든 데이터가 집합의 원소로 사용 할 수 있는 것은 아니다. Hashable이면서 변경 불가능한 자료형만이 집합의 원소로 사용 가능하다.

페이지 아래 예제를 참고하기 바란다.

- 중괄호 { }와 set() 함수를 사용하여 생성할 수 있다.

>>> a = set()

>>> b = {1, 2, 3}

>>> a set()

>>> b {1, 2, 3}

>>> a = [1,2]

>>> b = [3, 4]

>>> c = {a,b}

Traceback (most recent call last):

File "<stdin>", line 1, in <module>

TypeError: unhashable type: 'list'

>>> a = (1,2)

>>> b = (3,4)

>>> c = {a, b}

>>> c {(1, 2), (3, 4)}

* 왼쪽 예제는 원소의 값이 변경 가능한 리스트로 집합을 생성할 때 Error가 발생한다.

* 오른쪽 예제는 한번 생성하면 값 변경이 불가능한 튜플로 집합을 생성하면 정상적으로 동작한다.

5. 기능소개

5.2 Python 자료형(집합)(7/7)

▪ 집합(Set)

- 집합은 수학의 집합처럼 연산이 가능하다.

>>> a = {1, 2, 3, 4, 5, 6}

>>> b = {4, 5, 6, 7, 8, 9}

>>> a | b

{1, 2, 3, 4, 5, 6, 7, 8, 9}

➢ | 연산자를 사용하여 합집합 연산을 한다.

>>> a & b {4, 5, 6}

➢ & 연산자를 사용하여 교집합 연산을 한다.

>>> a - b {1, 2, 3}

➢ - 연산자를 사용하여 차집합 연산을 한다.

>>> a ^ b {1, 2, 3, 7, 8, 9}

➢ ^ 연산자를 사용하여 대칭 차집합 연산을 한다

5. 기능소개

5.3 Python 도움말 얻기

▪ dir() 함수와 help를 사용하여 객체가 가지고 있는 메서드 및 도움말을 얻는 방법을 알아보자. dir() 함수를 사용하면 객체가 가지고 있는 메서드 리스트가 출력된다.

>>> dir(list)

['__add__', '__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__iadd__', '__imul__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']

>>> dir(tuple)

['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'count', 'index']

>>> dir(dict)

['__class__', '__contains__', '__delattr__', '__delitem__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'items', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values']

>>> dir(set)

['__and__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__iand__', '__init__', '__init_subclass__', '__ior__', '__isub__', '__iter__', '__ixor__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__or__', '__rand__', '__reduce__', '__reduce_ex__', '__repr__', '__ror__', '__rsub__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__xor__', 'add', 'clear', 'copy', 'difference',

'difference_update', 'discard', 'intersection', 'intersection_update', 'isdisjoint', 'issubset', 'issuperset', 'pop', 'remove', 'symmetric_difference', 'symmetric_difference_update', 'union', 'update']

* 출력 결과에서 __가 붙지 않은 문자열이 메서드의 이름이다. (예: append, clear, copy…. )

>>> help(dict.update) Help on method_descriptor:

update(...)

D.update([E, ]**F) -> None. Update D from dict/iterable E and F.

If E is present and has a .keys() method, then does: for k in E: D[k] = E[k]

If E is present and lacks a .keys() method, then does: for k, v in E: D[k] = v In either case, this is followed by: for k in F: D[k] = F[k]

* help() 함수를 사용하여 dict 객체의 update의 도움말을 출력한다.

5. 기능소개

5.4 Python 자료형 특징

• Python 자료형을 아래와 같이 정리하면 아래와 같다.

▪ List

✓ 내용을 변경 할 수 있다.

✓ 리스트 함수를 사용하여 항목을 삽입하거나 삭제 가능하다.

▪ Tuple

✓ 메모리에서 빠르게 동작한다.

✓ 항목을 삽입하거나 삭제 불가하다.

▪ Dictionary

✓ 항목을 가리키는 고유한 이름을 가지고 있다.(Key)

✓ 인덱스로 key 이름을 사용한다.

✓ Value에는 문자열, 정수, 실수, Tuple과 List가 사용 가능하다.

✓ 콜론으로 Key와 Value을 구분하고 Key 값은 중복이 되면 안된다.

✓ key 값을 중복으로 입력은 가능하지만 어느 Value을 가져올지는 모른다.

✓ Hash table을 사용하여 빠른 속도로 동작한다.

5. 기능소개

5.5 Python 제어문(if와 Code Block)(1/3)

• Python 인터프리터는 사용자가 입력한 순서대로 순차적으로 명령문을 하나씩 실행한다. 코드 를 작성하다 보면 순차적인 흐름을 바꾸어 특정 조건일 때만 실행을 해야 할 경우가 생긴다.

특정 조건을 가진 명령문을 조건문이라고 한다.

• if문의 사용법은 아래와 같다.

• Python의 특징 중 하나는 Python은 조건문을 사용할 때 해당 조건에 영향 받는 명령문들을 Code Block이라는 간격으로 인식한다. 위의 예제에서 빨간색 박스는 공백(혹은 탭)을 의미한 다. 조건식의 다음 차례의 명령문이 공백문자를 가지고 있다면 해당 명령문은 위의 조건문에 종속되어 있다. 조건이 참일 경우 명령문은 실행되고 거짓일 경우 실행되지 않는다.

if 조건식:

명령문 elif 조건식:

명령문 else:

명령문

a = 12 if a > 15 :

print ("15보다 큽니다.") elif a > 10 :

print ("10보다 큽니다.") else:

print ("10보다 작습니다.")

>> 10보다 큽니다.

조건이 참이라면

해당 줄의 명령문이 실행후 종료

위의 조건이 거짓이면 elif 조건식을 검사 조건이 참이면 실행 후 종료

위의 조건들이 다 거짓일 경우 else문 다음 명령문이 실행

a는 12로 할당되고 조건문의 첫번째는 a가 15보다 큰가를 조사한다. 거짓이기 때문에 다 음 블럭에 있는 명령문은 실행 되지 않고 다음 조건으로 넘어 간다. 두번째 조건이 참이기 때문에 조건문 다음 명령문이 실행되고 조건문은 종료

Code Block

* elif : else if의 줄인 말

5. 기능소개

5.5 Python 제어문(for)(2/3)

• 흐름을 제어하는 또 다른 방법은 같은 부분을 반복해서 실행 하는 것이다. 이를 반복문이라고 한다.

• 반복문은 사용자가 얼마큼 반복할 것인지 정할 수 있다.

• For는 가장 많이 사용하는 반복문이며, 형식은 아래와 같다.

• <object>는 sequence형 데이터여야 한다.

• <object>의 각 항목은 <target>에 치환되어 명령문 실행한다.

• 반복의 횟수는 <object>의 크기에 결정된다.

• for 문의 내부 블록에서 continue를 만나면 시작 부분으로 이동, break를 만나면 for문의 내부 블록을 종료한다.

• for를 사용할 수 있는 객체는 아래와 같다.

✓ 문자열, 리스트, 튜플, 사전, range, 반복이 가능한 객체 for <target> in <object> :

명령문

for x in [...]:

continue break

이후 소스...

이전 소스...

continue를 만나면 break를 만나면

* 조건문에는 반드시 조건식 뒤에 : 를 붙인다.

5. 기능소개

5.5 Python 제어문(while)(3/3)

• for 문과 같은 반복문이며, 조건문이 거짓으로 판별되기 전까지 계속 반복된다.

• 시작 부분의 <조건>을 검사해서 결과가 참 이면 내부 블록이 반복적으로 실행된다.

while 조건문:

continue

break

이후 소스...

이전 소스...

continue를 만나면

break를 만나면

while 조건:

명령문

• 반복문에서 continue를 만나면 만나면 시작 부분으로 이동

• break를 만나면 while 문의 내부 블록을 종료

• while 문은 조건이 잘못 설정되면 무한루프에 빠질수 있다.

아래 코드는 while 문의 조건은 항상 참이기 때문에 계속해 서 무한으로 반복할 것이다.

i = 0 while i < 1:

print (i)

* i는 항상 0이기 때문에 조건은 항상 참이다.

문서에서 제대로 배워보자 (페이지 36-49)

관련 문서