검색결과 리스트
리스트에 해당되는 글 3건
- 2020.05.18 파이썬 (Python) 리스트 (3) - 리스트 슬라이싱과 역인덱스
- 2020.04.19 파이썬 (Python) 리스트 (2) - 리스트 제어 함수
- 2020.04.15 파이썬 (Python) 리스트 (1) - 리스트를 만들어보쟈
글
파이썬 (Python) 리스트 (3) - 리스트 슬라이싱과 역인덱스
근 한달만에 정리를 하게 되었습니댜..
그동안 일이 조금 많기도 하고, 게으름도 조금 부렸었는데 다시 한번 잊어버릴라...
이전 파이썬 리스트에 대해 알아보았었는데, 오늘은 조금 더 심화시켜 리스트의 슬라이싱.
그리고 역인덱스를 파보도록하죠.
(사실 내가 안까먹기 위한 공부댜..)
1. 리스트 슬라이싱
파이썬에 입문하며 조금 생소했던 부분인데, 리스트 슬라이싱..
이눔.... 생각보다 중요합니다. (많이!)
이게 슬라이싱을 구성하는 기본 문법입니다.
간단히 사용사례를 스노우타운 주민들 리스트로 살펴볼겁니다. 문법자체보다는 다른 의미가 더 깊기 때문이죠.
한장으로 리스트 슬라이싱 문법과 사용케이스 끝낼테니 잘 보세요! 스노우타운 주민 여러분!!
자 본래 의미 고찰... 이녀석을 꺼낸 이유는 따로 있습니다.
바로.. 리스트 2장에서 살펴보았던, copy() 함수와 객체별 레퍼런스의 메모리 주소값의 연장선이죠.
이 녀석. 슬라이싱을 0번 앙몬드부터 시작하건, 중간에 2개씩 끊건. 우리는 하나의 "스노우타운_마을주민_리스트" 를 통해서 슬라이싱을 모두 끝냈습니다.
즉, 원본 리스트의 데이터값을 유지한채로 새로운 콜렉션을 탄생시켰댜.....
이거 생각보다 중요합니다.
호스팅 환경에 부담을 최대한 덜면서 원본 데이터 백업 및 데이터 처리가 가능하다는 의미이죠!
10만건 정도의 대량의 데이터가 있다고 가정하고, 그 대용량 데이터를 원본 손상 없이, 야금야금 떼어내서 처리한다. 문제가 생기면 바로 그 원본 데이터로 롤백시키면 된다..
사실 이것때문에 리스트 슬라이싱을 뽑아본 거였습니다. 개발의 세계에서는 이를 원본 데이터를 손상시키지 않는다하여, "비파괴동작" 이라고 부르죠. 그럼 "파괴동작"은 뭐가 있을까요?
전장에서 보았던, insert, append, remove, pop... 모두 원본 데이터를 조작해 기존 리스트가 변경되었었죠?
파괴동작입니다.
자 그럼 다시 2장에서 꺼내보았던 id함수를 또 여기서 써보도록 하죠. 무슨 주소값이 나올까요?
스노우타운 마을주민 리스트의 원본 메모리주소 (1)과, 슬라이싱 했을 때의 주소가 다른 것을 볼 수 있습니다.
즉 파이썬 실행 시, 인터프리터가 슬라이싱에 대하여 새로운 메모리 주소를 할당하고 그에 대해 쓰는 것을 알 수 있습니다.
***** 노트노트.....
2. 마이너스 인덱스
일반적으로 우리가 리스트나 배열하면, 0번부터 인덱스가 시작한다고 생각을 하죠.
0이 첫 값부터 쭈욱 시작하면, 마이너스 인덱스는 맨 마지막부터 첫 값까지 가요!
마이너스 인덱스를 통해, 데이터를 처리할 때 조금 더 센스를 발휘해보면 다른 개발자들도 뭔가 재미나게 로직을 꾸밀 수도 있는 상황이 올겁니다 :)
슬라이싱 자체는, 솔직히 저거를 왜 쓰는건가.. 라기보다는 특수 상황에서의 유용성. 그리고 가장 중요한
원본데이터를 그대로 보존시키면서 데이터 작업이 가능하다. 비파괴동작..
을 꼭 기억하고 가셨으면 합니다.
으.. 또 7시간 뒤면 출근해야한다.... 이만 개발자 앙몬드는 슬슬 자러갑니다...
'IT > Python3' 카테고리의 다른 글
AWS EBS 네임태그 자동화 람다 (0) | 2020.08.17 |
---|---|
AWS ELB 네임태그 생성 자동화 스크립트 (0) | 2020.08.10 |
파이썬 (Python) 리스트 (2) - 리스트 제어 함수 (0) | 2020.04.19 |
파이썬 (Python) 리스트 (1) - 리스트를 만들어보쟈 (0) | 2020.04.15 |
파이썬 기초 - 콜렉션 (0) | 2020.04.13 |
글
파이썬 (Python) 리스트 (2) - 리스트 제어 함수
리스트를 만들었는데 안에 있는 데이터를 만질 일이 생길 수 있어요.
이번 편에서는 리스트 데이터를 만질 수 있는 방법 요약을 해봅시댜.
☆역순 탐색에 해당하는 -1부터 시작하는 인덱스는 (2) 편에서는 다루지 않고, 리스트 후속편에서 다루도록할게요!
☆-1 인덱스는 range와 리스트 슬라이싱과 연관이 많기떄문에, 리스트만 다루는 본 2장에서는 잠깐 패스!
1. pop() 함수 - 리스트의 데이터를 인덱스로 삭제하고, return으로 받아오는 함수입니댜.
스카피 리스트를 만들고, 하나의 백업본을 만들었는데
삭제하는 함수는 remove가 아니라 pop을 사용합니다.
remove에 대해서는 2번에서 알아볼거예요.
한번 출력해보면?
스카피 리스트의 0번 인덱스, 값이 3인 여석이 없어진 것을 확인했습니다.
1번 주제가, pop() 삭제함수는, return을 한다고 했는데 그 값도 받아오는지 확인해봐야죠?
대입/출력 코드를 합해서 테스트드라이브 결과 받아왔어요.
그럼 흔히 알고있는 remove함수와의 차이는?
2. remove() 함수 - 리스트의 데이터를 객체의 값으로 삭제합니댜
pop( index ) vs remove( value )
이것이 pop과 remove 함수의 결정적인 차이입니댜
인덱스로 리스트 데이터를 저격할 것인가, 아니면 값으로 데이터를 저격할 것인가.
우선, remove를 한번 써보고 결과를 봐보도록 하죠.
pop 데이터는 return으로 그 pop된 데이터를 들고왔지만, remove는 None을 리턴하고 있어요.
왜 값을 리턴하지 않을까?
이미 value 기준으로 값을 제거했는데, 그 삭제된 value를 다시 리턴해주는 것이 맞을까요?
인덱스로 접근시에는 그 값의 정체를 모르지만, value로 접근시에는 이미 내가 그 값의 정체를 알고 있기 때문에, 따로 value를 리턴해줄 필요는 없습니다.
None 은 흔히 다른 언어에서는 공통적으로 null value에 해당합니다. 혹은 다른 친구들과도 비교하자면, Void 객체, 대다수가 알고있는 Javascript 에서는 Undefined 객체와 비슷한 친구예요.
3. copy() 함수 - 해당 리스트 메모리에 할당된 데이터들에 대한 복제본을 만들어요
파이썬 또한 각 객체의 네이밍들은 객체, 즉 레퍼런스들입니다. C언어, C++ 등에서는 포인터로 표현되었죠. 메모리를 가리키는 주소값입니다.
A = [1,2,3] # ... A라는 변수에 [1,2,3] 을 할당해, 그 레퍼런스를 붙였어요
B = A # ... B라는 변수에 A라는 레퍼런스를 다시 붙였어요
2개 모두 [1,2,3] 을 가리킵니다.
이 때, A.pop(0) 을 하고, B를 출력해볼까요?
여기서 차이가 생깁니다. B와 A 모두 [1,2,3] 가 할당된 메모리 주소를 같이 가리키게 되는데, B라는 변수에 A라는 레퍼런스를 대입하며 벌어지게 된 일입니다.
위 예시 코드를 좀 더 확장해서 차이점을 볼까요? 이번엔 파이썬의 메모리 주소를 확인하는 id() 라는 함수를 써서 딥 다이브해볼거예요.
위 예시코드에, id() 를 추가했고, A = [1,2,3] B = [1,2,3] 을 따로 설정해보았어요.
보시는 바와 같이, 첫번째 B=A 는 같은 메모리주소 57400968 같은 메모리 주소를 가리키고 있네요.
A가 바라보는 57400968 메모리주소의 [1,2,3] 에서 pop을 하니, B가 바라보는 57400968 도 같이 pop이 되는 것이죠.
반대로, 아래 추가 예시코드는, A와 B 모두 [1,2,3] 따로 할당 후, A만 pop하여도 B의 데이터는 그대로 남아있죠.
아래 A와 B 추가코드의 메모리 주소도 다른 것을 확인할 수 있습니다.
먼 길을 돌아, 다시 copy 함수.... (음...)
데이터 처리 시, 원본 데이터를 한번 백업해두어야 하는 일이 있습니다.
위처럼, [1,2,3] 단순하다면 상관 없겠으나, 그게 수백건으로만 올라가도, 저렇게 하드코딩해서 대입하여 백업할 수 없는 노릇!
이 때 copy() 함수를 써서 새로운 메모리 공간을 할당해 백업해주는 좋은 꿀팁이 있어요!
방법은 간단합니다.
원하는 리스트에, copy() 함수 하나만 붙여 다른 객체에 할당해주면 끝!
결과를 보시면, pop 했는데도, B의 [1,2,3] 데이터는 그대로 남아있어요.
메모리 주소를 확인해봐도, A와 B가 같은 주소를 가졌던 것에 반해, 다른 메모리 주소가 할당된 것을 확인할 수 있죠!
copy() 함수는 유용하지만, 너무 큰 데이터를 동시에 백업할 때는, 호스팅 환경에 굉장한 부담을 줄 수 있습니다.
(어쩌다보니 카피함수와 메모리 주소, 레퍼런스의 개념까지 요약하다보니 이게 제일 길어졌댜...)
4. append() - 리스트에 데이터를 뒤에 계속 가져다 붙여놓는 함수
삭제해봤으니 추가도 해봐야죠? 리스트 뒤에 하나하나씩 데이터를 할당 생성하는 함수입니다.
쉬워요!
앙몬드 스트링 데이터를 붙여 넣으니, 스카피리스트 데이터에 잘 붙어 들어갔습니다.
remove와 마찬가지로, value 기반 호출이니, 따로 return 값이 없는 것을 볼 수 있습니다.
5. extend() - 리스트에 리스트를 붙여 확장하는 함수
append()가 단일값으로 데이터를 추가하는 함수였다면,
extend() 는 아예 리스트 자체를 덧붙여 추가하는 함수입니다.
1 vs n 의 관계라고 보면 편하겠어요!
방금 앙몬드를 append 했던 스카피리스트 자체를, 스카피리스트에 extend 하니 곱절로 불어났네요!
(앙몬드가 2명)
이번에도 리턴값은 없습니다. 함수 실행 후, 그에 대한 데이터 값은, 스카피_리스트 자체 내에 있기 때문에, 별도의 리턴값은 필요없겠죠?
6. insert() - 리스트의 특정 위치 (인덱스) 에 데이터 삽입하기 (새치기)
취소선은 그었지만.. 진짜 줄서있는 데이터 중간에 새치기해서 끼워넣기.. 라는 말이 최적 (ㅇㅈ)
특정 위치 - 인덱스에, 데이터를 끼워 넣습니다. 이 녀석은 파라미터가 2개로 지정되어 있으니, 규격을 글로 써볼게요.
리스트.insert( 인덱스-끼워넣을 위치 , 값-그 인덱스에 끼워넣을 값)
원래 스카피 리스트는 [3, 1, 2, ...., '앙몬드] 였어요.
즉, 0번 인덱스에는 3이란 값이 있었지만, 여기에 "케로와 베로니" 를 새치기시켰습니다.
원래 3이란 값은 새치기를 당해, 이제는 1번 인덱스로 가게 되었네요!
(앙몬드들도 한칸씩 밀렸다)
7. sort() & reverse() - 리스트를 순차/역순 정렬하는 함수
리스트를 보기 좋게 정렬해주는 함수입니다.
그냥 한번 둘러보시면 아 이렇구나 하고 알게 될거예요! (근데 주의하실 것도 있습니다.)
원래 숫자만 있었던 카피_리스트를 재사용해봤어요.
3,1,2,4,5 무작위였던 녀석이, sort() 하니 자동 오름차순 정렬되었어요!
아래에서는 그 카피_리스트를 reverse() 해보니 내림차순 정렬되었습니다.
근데 주의사항이 있었죠?
리스트의 정렬은 내부 타입이 일관성이 있어야 한다는 점이죠!
숫자 리스트안에 문자나, 딕트, 세트 등 동일 대상 비교가 불가한 녀석들이 섞인 잡동사니 리스트에서는 쓸 수 없다는 점 유의해두세요!
원래는 간단하게 제 자신이 까먹지 않기 위해 쓰는 글이었는데, 어느 순간부터 글이 점점 늘어가는 기이한 일이...
무튼.. 다음 편에서는 이 리스트에 대한 슬라이싱과 마이너스 인덱스, range 에 대해서 더 딥다이브를 해보도록 하죠!
'IT > Python3' 카테고리의 다른 글
AWS EBS 네임태그 자동화 람다 (0) | 2020.08.17 |
---|---|
AWS ELB 네임태그 생성 자동화 스크립트 (0) | 2020.08.10 |
파이썬 (Python) 리스트 (3) - 리스트 슬라이싱과 역인덱스 (0) | 2020.05.18 |
파이썬 (Python) 리스트 (1) - 리스트를 만들어보쟈 (0) | 2020.04.15 |
파이썬 기초 - 콜렉션 (0) | 2020.04.13 |
글
파이썬 (Python) 리스트 (1) - 리스트를 만들어보쟈
그 흔한 리스트.
파이썬은 특이한게, 타입 지정이 없어요. (사실 JS도 그런데..)
다 객체로 취급하기 때문에, 리스트 안의 데이터들도 특별한 타입 지정 없이 죄다 박혀 들어가요
한번 보도록 하죠 :)
대괄호로 표현하는게 특이한데, 앵간한 언어들의 대괄호 초기화는 배열을 의미했는데,
파이썬에서는 특별히 배열만 따로 분리되어 설명하는 개념은 없더라구요.
1번 공백 리스트, 2번 잡동사니 리스트, 3번 리스트와 잡동사니가 섞인 리스트, 4번처럼 iterable 객체를 다시 리스트로 변환하여 초기화한 리스트. 그 외 여러가지가 많습니다.
ps) print의 f는 파이썬3부터 지원하는, f-string 기능입니다. 구글링해보시면 능력자들의 더 뛰어난 글들을 만나보실 수 있어요!
ps) iterable 의 영문 의미는 "반복가능한" 이란 의미입니다. 뜻에서부터 유추 가능하듯, 반복, 즉 루프로 돌릴 수 있는 녀석들은 대개 iterable 객체로 집어넣을 수 있어요!
초기화도 해봤으니 간단한 출력 테스트 드라이브..
뒤 이어, 리스트의 데이터를 수정할 수 있는 함수들과, 기타 유용한 기능들을 알아보도록 하죠 :)
'IT > Python3' 카테고리의 다른 글
AWS EBS 네임태그 자동화 람다 (0) | 2020.08.17 |
---|---|
AWS ELB 네임태그 생성 자동화 스크립트 (0) | 2020.08.10 |
파이썬 (Python) 리스트 (3) - 리스트 슬라이싱과 역인덱스 (0) | 2020.05.18 |
파이썬 (Python) 리스트 (2) - 리스트 제어 함수 (0) | 2020.04.19 |
파이썬 기초 - 콜렉션 (0) | 2020.04.13 |