반응형
소개
파이썬의 pandas 라이브러리를 사용하다보면 'TypeError: 'int' object is not subscriptable'라는 오류에 봉착할 수 있습니다. 이 오류는 주로 정수형(int) 객체를 리스트나 데이터프레임과 같은 서브스크립트 방식으로 접근하려 할 때 발생합니다. 이번 블로그 글에서는 이 오류의 원인과 해결 방법을 안내하겠습니다.
에러 발생 예시 코드
먼저, 이 오류가 발생할 수 있는 간단한 예시 코드를 살펴보겠습니다.
import pandas as pd
# 데이터프레임 생성
data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)
# 정수형 변수를 설정
row_index = 1
# 잘못된 서브스크립트 접근
value = df[row_index][1] # TypeError 발생
print(value)
에러 해결 방법
1. 올바른 데이터 접근 방법 사용
이러한 오류를 피하기 위해서는 정수형 인덱스를 사용하여 데이터프레임에 접근할 때 올바른 방법을 사용하는 것이 중요합니다. 아래 코드를 통해 각 열의 특정 값에 접근할 수 있습니다.
import pandas as pd
# 데이터프레임 생성
data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)
# 올바른 서브스크립트 접근
value = df.iloc[row_index, 1] # 이렇게 해야 합니다
print(value)
2. 데이터프레임의 모양 확인
데이터프레임에 대해 잘못된 인덱스를 사용하고 있을 수도 있습니다. 따라서 데이터프레임의 모양을 확인하는 것도 좋은 방법입니다.
import pandas as pd
# 데이터프레임 생성
data = {'A': [1, 2, 3], 'B': [4, 5, 6]}
df = pd.DataFrame(data)
# 데이터프레임 모양 확인
print(df.shape) # (3, 2) : 3행, 2열
# 안전하게 값에 접근하기
if 1 < df.shape[0] and 1 < df.shape[1]:
value = df.iloc[1, 1]
print(value)
else:
print("인덱스가 데이터프레임의 범위를 벗어났습니다.")
마무리
이번 블로그 글에서는 pandas에서 발생할 수 있는 'TypeError: 'int' object is not subscriptable' 오류에 대해 알아보았습니다. 올바른 데이터 접근 방법인 iloc를 사용하거나 데이터프레임의 모양을 확인함으로써 이러한 오류를 피할 수 있습니다. pandas를 사용할 때는 항상 데이터 구조를 이해하고 적절한 메서드를 활용하여 코드의 효율성을 높이는 것이 중요합니다.
반응형
'Python > Pandas' 카테고리의 다른 글
pandas ValueError: Input contains NaN, infinity 오류 해결하기 (2) | 2025.07.11 |
---|---|
pandas ValueError: Index must be monotonic increasing or decreasing 오류 해결하기 (0) | 2025.07.11 |
pandas TypeError: 'Series' object is not callable 오류 해결하기 (0) | 2025.07.10 |
pandas.rolling로 이동 평균 계산하기 (1) | 2025.07.10 |
pandas.expanding으로 누적합 계산하기 (1) | 2025.07.10 |