리스트: 두 판 사이의 차이
보이기
코드 예시를 lang="pycon" 대화형 블록으로 통합, REPL 출력 의미에 맞게 수정 |
리스트 예시를 노트북 스타일 입력/출력 쌍으로 재구성하고 슬라이싱·remove·pop 결과를 분리해 명확히 제시 |
||
| 7번째 줄: | 7번째 줄: | ||
리스트 <code>l</code>에 대해 인덱스 <code>i</code>의 원소는 <code>l[i]</code>, 인덱스 <code>i</code>부터 <code>j-1</code>까지의 원소는 <code>l[i:j]</code>, 인덱스 <code>i</code>부터 <code>j-1</code>까지 <code>k</code> 간격의 원소는 <code>l[i:j:k]</code>로 가리킨다. | 리스트 <code>l</code>에 대해 인덱스 <code>i</code>의 원소는 <code>l[i]</code>, 인덱스 <code>i</code>부터 <code>j-1</code>까지의 원소는 <code>l[i:j]</code>, 인덱스 <code>i</code>부터 <code>j-1</code>까지 <code>k</code> 간격의 원소는 <code>l[i:j:k]</code>로 가리킨다. | ||
<syntaxhighlight lang=" | <syntaxhighlight lang="python" line> | ||
l = [1, 2.5, 'data', [4, 3], 1.0, 1.5, 2] | |||
l[2] | |||
</syntaxhighlight> | |||
<syntaxhighlight lang="text"> | |||
'data' | 'data' | ||
>> | </syntaxhighlight> | ||
<syntaxhighlight lang="python" line start="3"> | |||
l[1:4] | |||
</syntaxhighlight> | |||
<syntaxhighlight lang="text"> | |||
[2.5, 'data', [4, 3]] | [2.5, 'data', [4, 3]] | ||
>> | </syntaxhighlight> | ||
<syntaxhighlight lang="python" line start="4"> | |||
l[0:7:2] | |||
</syntaxhighlight> | |||
<syntaxhighlight lang="text"> | |||
[1, 'data', 1.0, 2] | [1, 'data', 1.0, 2] | ||
</syntaxhighlight> | </syntaxhighlight> | ||
| 31번째 줄: | 43번째 줄: | ||
<code>remove</code>는 값을 기준으로, <code>pop</code>은 인덱스를 기준으로 원소를 삭제한다. | <code>remove</code>는 값을 기준으로, <code>pop</code>은 인덱스를 기준으로 원소를 삭제한다. | ||
<syntaxhighlight lang=" | <syntaxhighlight lang="python" line start="5"> | ||
l = [1, 2.5, 'data', [4, 3], 1.0, 1.5, 2] | |||
l.remove(2.5) | |||
>> | l | ||
</syntaxhighlight> | |||
<syntaxhighlight lang="text"> | |||
[1, 'data', [4, 3], 1.0, 1.5, 2] | [1, 'data', [4, 3], 1.0, 1.5, 2] | ||
</syntaxhighlight> | </syntaxhighlight> | ||
| 40번째 줄: | 54번째 줄: | ||
<code>remove(2.5)</code>는 값이 <code>2.5</code>와 같은 원소를 삭제한다. | <code>remove(2.5)</code>는 값이 <code>2.5</code>와 같은 원소를 삭제한다. | ||
<syntaxhighlight lang=" | <syntaxhighlight lang="python" line start="8"> | ||
l = [1, 2.5, 'data', [4, 3], 1.0, 1.5, 2] | |||
l.pop(2) | |||
</syntaxhighlight> | |||
<syntaxhighlight lang="text"> | |||
'data' | 'data' | ||
>>> | </syntaxhighlight> | ||
<syntaxhighlight lang="python" line start="10"> | |||
l | |||
</syntaxhighlight> | |||
<syntaxhighlight lang="text"> | |||
[1, 2.5, [4, 3], 1.0, 1.5, 2] | [1, 2.5, [4, 3], 1.0, 1.5, 2] | ||
</syntaxhighlight> | </syntaxhighlight> | ||
2026년 6월 15일 (월) 17:19 기준 최신판
리스트(list)는 여러 값(원소)을 담을 수 있는 객체(object)를 뜻한다. 리스트는 대괄호 [, ]로 나타낸다. 메서드(method)는 특정 객체에 속한 함수(function)로, 리스트에 저장된 데이터를 조작하거나 정보를 얻는 데 사용된다. 리스트의 각 원소는 인덱스(index)로 가리키며, 인덱스는 0부터 시작한다.
인덱스와 슬라이싱
인덱스는 리스트에서 특정 순번의 원소를 가리키는 번호로, 0부터 시작한다. 여러 원소를 한 번에 가리키는 방법을 슬라이싱(slicing)이라 한다.
슬라이싱
리스트 l에 대해 인덱스 i의 원소는 l[i], 인덱스 i부터 j-1까지의 원소는 l[i:j], 인덱스 i부터 j-1까지 k 간격의 원소는 l[i:j:k]로 가리킨다.
l = [1, 2.5, 'data', [4, 3], 1.0, 1.5, 2]
l[2]
'data'
l[1:4]
[2.5, 'data', [4, 3]]
l[0:7:2]
[1, 'data', 1.0, 2]
메서드
리스트가 가진 유용한 메서드는 다음과 같다.
list.append(x): 리스트의 끝에 원소x를 추가한다.list.insert(i, x): 인덱스i의 위치에 원소x를 추가한다.list.extend(s): 리스트의 끝에 객체s의 모든 원소를 추가한다.list.remove(x): 값이x와 같은 첫 번째 원소를 삭제한다.list.count(x): 원소x의 개수를 센다.list.index(x): 원소x가 처음 나타나는 인덱스를 찾는다.list.pop(i): 인덱스i의 원소를 삭제한다.
remove와 pop
remove는 값을 기준으로, pop은 인덱스를 기준으로 원소를 삭제한다.
l = [1, 2.5, 'data', [4, 3], 1.0, 1.5, 2]
l.remove(2.5)
l
[1, 'data', [4, 3], 1.0, 1.5, 2]
remove(2.5)는 값이 2.5와 같은 원소를 삭제한다.
l = [1, 2.5, 'data', [4, 3], 1.0, 1.5, 2]
l.pop(2)
'data'
l
[1, 2.5, [4, 3], 1.0, 1.5, 2]
pop(2)는 인덱스 2(0부터 세어 세 번째 원소)인 'data'가 삭제된다.