딕셔너리와_집합
-  description : 딕셔너리와_집합 
-  author      : 도봉산핵주먹 
-  email       : hylee@repia.com 
-  lastupdate  : 2020-06-22 
 
딕셔너리와_집합
예제 코드
# Section04-4
# 파이썬 데이터 타입(자료형)
# 딕셔너리, 집합 자료형
 
# 딕셔너리 자료형(순서X, 중복X, 수정O, 삭제O)
# Key, Value (Json) -> MongoDB
 
# 선언
print('#==== 딕셔너리 ====#')
a = {'name': 'Kim', 'phone': '01012345678', 'birth': 870124}
b = {0: 'Hello python!'}
c = {'arr': [1, 2, 3, 4]}
 
print('#=== type, 값 출력 ===#')
print('a - ', type(a), a)
print('b - ', type(b), b)
print('c - ', type(c), c)
 
print()
 
# 출력
print('#=== 값 출력 방법 ===#')
print('a - ', a['name'])  # 존재X -> 에러 발생
print('a - ', a.get('name'))  # 존재X -> None 처리
print('b - ', b[0])
print('b - ', b.get(0))
print('c - ', c['arr'])
print('c - ', c['arr'][3])
print('c - ', c.get('arr'))
 
print()
 
# 딕셔너리 추가
print('#=== 딕셔너리 추가 ===#')
a['address'] = 'seoul'
print('a - ', a)
a['rank'] = [1, 2, 3]
print('a - ', a)
 
print()
 
# dict_keys, dict_values, dict_items : 반복문(iterate) 사용 가능
# dict_items -> dict 전체
print('#===  dict_keys, dict_values, dict_items 알아보기 ===#')
print('a - ', a.keys()) 
print('b - ', b.keys())
print('c - ', c.keys())
 
print()
 
print('a - ', list(a.keys()))
print('b - ', list(b.keys()))
print('c - ', list(c.keys()))
 
print()
 
print('a - ', a.values())
print('b - ', b.values())
print('c - ', c.values())
 
print()
 
print('a - ', list(a.values()))
print('b - ', list(b.values()))
print('c - ', list(c.values()))
 
print()
 
print('a - ', a.items())
print('b - ', b.items())
print('c - ', c.items())
 
print()
 
print('a - ', list(a.items()))
print('b - ', list(b.items()))
print('c - ', list(c.items()))
 
print()
 
print('a - ', 'name' in a)
print('a - ', 'addr' in a)
 
print()
# Key만 가져오고 index로 접근 안됨.
# index로 접근하려변 변수화 해서 가져와야됨.
print('#== dict_keys 나 values는 변수화 해서 index값으로 접근하기 ==#')
temp = list(a.keys())
print(temp[1:3])
# Key만 가져오고 index로 접근 안됨.
 
print()
print()
 
print('#==== 집합 ====#')
# 집합(Sets) 자료형(순서X, 중복X)
 
# 선언
a = set()
b = set([1, 2, 3, 4])
c = set([1, 4, 5, 6])
d = set([1, 2, 'Pen', 'Cap', 'Plate'])
 
print('#=== type, 값 출력 ===#')
print('a - ', type(a), a)
print('b - ', type(b), b)
print('c - ', type(c), c)
print('d - ', type(d), d)
 
print()
 
# 튜플 변환
print('#=== 튜플로 변환 ===#')
t = tuple(b)
print('t - ', type(t), t)
print('t - ', t[0], t[1:3])
 
print()
 
# 리스트 변환
print('#=== 리스트로 변환 ===#')
l = list(c)
print('l - ', type(l), l)
print('l - ', l[0], l[1:3])
 
print()
 
print("#=== 집합 자료형 활용 ===")
# 집합 자료형 활용
s1 = set([1, 2, 3, 4, 5, 6])
s2 = set([4, 5, 6, 7, 8, 9])
 
 
print("#== 교집합 ==")
print('l - ', s1 & s2)
print('l - ', s1.intersection(s2))
 
print("#== 합집합 ==")
print('l - ', s1 | s2)
print('l - ', s1.union(s2))
 
print("#== 차집합 ==")
print('l - ', s1 - s2)
print('l - ', s1.difference(s2))
 
print()
 
print("#=== 집합 추가 / 제거 ===")
# 추가 & 제거
s1 = set([1, 2, 3, 4])
s1.add(5)
print('s1 - ', s1)
 
s1.remove(2)
print('s1 - ', s1)
 
실행 콘솔
#==== 딕셔너리 ====#
#=== type, 값 출력 ===#
a -  <class 'dict'> {'name': 'Kim', 'phone': '01012345678', 'birth': 870124}
b -  <class 'dict'> {0: 'Hello python!'}
c -  <class 'dict'> {'arr': [1, 2, 3, 4]}
 
#=== 값 출력 방법 ===#
a -  Kim
a -  Kim
b -  Hello python!
b -  Hello python!
c -  [1, 2, 3, 4]
c -  4
c -  [1, 2, 3, 4]
 
#=== 딕셔너리 추가 ===#
a -  {'name': 'Kim', 'phone': '01012345678', 'birth': 870124, 'address': 'seoul'}
a -  {'name': 'Kim', 'phone': '01012345678', 'birth': 870124, 'address': 'seoul', 'rank': [1, 2, 3]}
 
#===  dict_keys, dict_values, dict_items 알아보기 ===#
a -  dict_keys(['name', 'phone', 'birth', 'address', 'rank'])
b -  dict_keys([0])
c -  dict_keys(['arr'])
 
a -  ['name', 'phone', 'birth', 'address', 'rank']
b -  [0]
c -  ['arr']
 
a -  dict_values(['Kim', '01012345678', 870124, 'seoul', [1, 2, 3]])
b -  dict_values(['Hello python!'])
c -  dict_values([[1, 2, 3, 4]])
 
a -  ['Kim', '01012345678', 870124, 'seoul', [1, 2, 3]]
b -  ['Hello python!']
c -  [[1, 2, 3, 4]]
 
a -  dict_items([('name', 'Kim'), ('phone', '01012345678'), ('birth', 870124), ('address', 'seoul'), ('rank', [1, 2, 3])])
b -  dict_items([(0, 'Hello python!')])
c -  dict_items([('arr', [1, 2, 3, 4])])
 
a -  [('name', 'Kim'), ('phone', '01012345678'), ('birth', 870124), ('address', 'seoul'), ('rank', [1, 2, 3])]
b -  [(0, 'Hello python!')]
c -  [('arr', [1, 2, 3, 4])]
 
a -  True
a -  False
 
#== dict_keys 나 values는 변수화 해서 index값으로 접근하기 ==#
['phone', 'birth']
 
 
#==== 집합 ====#
#=== type, 값 출력 ===#
a -  <class 'set'> set()
b -  <class 'set'> {1, 2, 3, 4}
c -  <class 'set'> {1, 4, 5, 6}
d -  <class 'set'> {1, 2, 'Plate', 'Cap', 'Pen'}
 
#=== 튜플로 변환 ===#
t -  <class 'tuple'> (1, 2, 3, 4)
t -  1 (2, 3)
 
#=== 리스트로 변환 ===#
l -  <class 'list'> [1, 4, 5, 6]
l -  1 [4, 5]
 
#=== 집합 자료형 활용 ===
#== 교집합 ==
l -  {4, 5, 6}
l -  {4, 5, 6}
#== 합집합 ==
l -  {1, 2, 3, 4, 5, 6, 7, 8, 9}
l -  {1, 2, 3, 4, 5, 6, 7, 8, 9}
#== 차집합 ==
l -  {1, 2, 3}
l -  {1, 2, 3}
 
#=== 집합 추가 / 제거 ===
s1 -  {1, 2, 3, 4, 5}
s1 -  {1, 3, 4, 5}
 
Tip