# 파이썬 리스트
리스트란 여러가지 데이터를 저장하는 자료구조입니다. 리스트를 이용하면 숫자나 문자열 등의 데이터를 다량의 변수를 선언하지 않고도 간단하게 표현할 수 있습니다.
무엇보다 Python에서의 리스트는 자료형에 구애받지 않고 자료형에 상관없이 한개의 리스트에 혼합하여 저장할 수 있는 장점이 있습니다.
1. 리스트의 생성 및 데이터 저장
1 2 3 4 5 6 | arr1 = [1,2,3,4,5] # ok arr2 = ["a","b","c","d"] # ok arr3 = ["1",2,"3",4,"babo"] # ok arr4 = [1,2,[3,4,5,6]] # ok arr5 = [] # 빈 리스트 생성 arr6 = list() # 빈 리스트 생성 | cs |
2. 인덱싱
리스트는 문자열과 같이 인덱싱을 적용하는것이 가능합니다. 리스트의 첫번째 요소를 0번 인덱스로 지정하고 마지막요소에 리스트의 크기-1 인덱스를 지정합니다.
- 참고 : 마지막 인덱스는 -1로 표현하고 1씩 감하여 이전 인덱스를 표현합니다.
1 2 3 4 5 | arr = [1,2,3,4,5] # a[0] == 1 # a[4] == 5 # a[-1] == 5 # a[-2] == 4 | cs |
만약, 리스트안에 다중으로 리스트가 들어있는 경우에는 인덱싱을 두번하여 중첩 리스트안에 있는 데이터에 접근할 수 있습니다.
1 2 3 | arr = [1,2,[1,2,3]] # arr[-1] == [1,2,3] # arr[-1][-1] == [3] | cs |
3. 슬라이싱
리스트는 문자열과 마찬가지로 인덱싱 뿐만아니라 슬라이싱 또한 가능합니다. 범위를 지정하여 시작 인덱스의 요소부터 마지막 인덱스의 요소로 구성된 리스트로 분할합니다.
1 2 3 | arr=[1,2,3,4,5] # arr[0:2] = [1,2] # arr[2:] = [3,4,5] | cs |
4. 리스트 요소 수정
리스트의 데이터를 변경하고 싶을 경우에는 해당 인덱스에 대입연산자를 사용하여 데이터를 삽입하면 됩니다.
1 2 3 | arr = [1,2,3,4,5] arr[0] = 5 # arr == [5,4,3,2,5] | cs |
# 객체의 복사
파이썬에서는 리스트도 객체에 해당하기 때문에 복사를 하게되면 바로보는 객체가 동일하기 때문에 두개의 리스트 중 하나만 변경해도 나머지 하나가 동일하게 수정되는 현상이 발생합니다.
1. shallow copy(얕은 복사)
1 2 3 4 5 6 7 8 9 10 11 | a = [1, 2, 3, 4] b = a print(b) b[2] = 5 print(b) print(a) #결과값 [1, 2, 3, 4] [1, 2, 5, 4] [1, 2, 5, 4] | cs |
a라는 변수를 선언하고 리스트를 만들어 a에 할당하면 a는 리스트객체의 주소가 저장된 변수가 됩니다.
그럼 a라는 변수의 값을 b라는 인자에 할당하였을 경우, b는 a와 같은 객체의 주소가 저장된 변수가 되는걸까요? 정답은 예,그렇습니다. b를 불러와 인덱스 2번의 값을 5로 변경하면, a에도 똑같이 적용되어 a의 값이 1,2,5,4가 되는 것을 위의 코드를 통하여 알 수 있습니다.
리스트는 값을 대입하면 값에 대한 메모리가 새로이 할당되는 것이 아닌 기존 값의 메모리 주소를 공유하기 때문에 발생하게 됩니다. 리스트 같은 경우 리스트 자체뿐만 아니라 리스트 내 요소들도 같은 주소를 공유하고 있습니다. 이를 Shallow Copy(얕은 복사)라고 부릅니다.
2. Deep Copy(깊은 복사)
이러한 현상을 방지하기 위해서는 Deep copy를 사용하여 복사하면 됩니다. 방법은 간단합니다. 기본라이브러리인 copy를 사용하는 방법이 있지만 더욱 간단한 사용을 위해 다른방법을 설명드리겠습니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | #1번 방법 a = [1, 2, 3, 4] b = a[:]#리스트 슬라이싱 print(b) b[2] = 5 print(b) print(a) #2번 방법 a = [1, 2, 3, 4] b = list(a)#리스트 내장함수사용 print(b) b[2] = 5 print(b) print(a) #결과값(1번과 2번 동일) [1, 2, 3, 4] [1, 2, 5, 4] [1, 2, 3, 4] | cs |
간단하게 리스트를 슬라이싱하여 대입하면 shallow copy가 일어나지 않습니다. 또 list 내장함수를 사용하면 Deep copy가 진행되어 리스트 복사문제를 해결 할 수 있습니다.
'Dev > python' 카테고리의 다른 글
[python] 딕셔너리(dictionary) (0) | 2019.02.13 |
---|---|
[python] 리스트 함수 (0) | 2019.02.11 |
[python] 문자열 함수 (0) | 2019.02.09 |
[python] 문자열 (0) | 2019.02.07 |
[python] 기본자료형 - 숫자 (0) | 2019.02.07 |