본문 바로가기
Python/Pandas

pandas TypeError: 'Series' object is not subscriptable 오류 해결하기

by PySun 2025. 5. 13.
반응형

소개

파이썬의 pandas 라이브러리를 사용하면서 'TypeError: 'Series' object is not subscriptable' 오류에 부딪히는 경우가 종종 있습니다. 이 오류는 Series 객체에서 인덱스를 사용하여 값을 가져오려 할 때 발생하는 문제입니다. 본 블로그에서는 이 에러가 발생하는 이유와 그것을 해결하는 다양한 방법에 대해 알아보겠습니다.

에러 발생 예시 코드

가장 먼저 이 문제를 일으킬 수 있는 아주 간단한 코드 예시를 살펴보겠습니다.

import pandas as pd

# 데이터프레임 생성
data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)

# 시리즈 객체에 대한 잘못된 접근
value = df['A'][2][0]
print(value)

에러 해결 방법

1. 올바른 인덱스 사용

Series 객체의 인덱스에 접근할 때는 한 번의 인덱스 접근으로 끝내야 합니다. 이 경우, 'df['A'][2]'로만 접근하면 됩니다.

import pandas as pd

# 데이터프레임 생성
data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)

# 올바른 인덱스 접근
value = df['A'][2]
print(value)

2. iloc 사용하기

인덱스 접근의 또 다른 방법은 iloc 속성을 사용하는 것입니다. 이 방법은 행과 열을 인덱스 번호로 쉽게 접근할 수 있게 해줍니다.

import pandas as pd

# 데이터프레임 생성
data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)

# iloc을 사용하여 값에 접근
value = df.iloc[2, 0]  # 2번째 행, 0번째 열
print(value)

마무리

이 블로그 글에서는 pandas에서 만나게 되는 'TypeError: 'Series' object is not subscriptable' 에러와 그 해결 방법에 대해 알아보았습니다. Series 객체에서는 인덱스 접근 시 주의가 필요하며, 올바른 방법을 따라야 합니다. df['A'][2] 또는 iloc을 사용하는 방법을 통해 문제를 해결할 수 있습니다. pandas를 사용할 때는 데이터 구조에 대한 이해를 바탕으로 다양한 접근 방식을 활용하여 데이터를 효과적으로 다루는 것이 중요합니다.

반응형