Python/xlwings

xlwings AttributeError: 'Workbook' object has no attribute 'add_worksheet' 해결하기

PySun 2024. 11. 28. 20:08
반응형

소개

xlwings를 사용하여 엑셀 작업을 자동화할 때, 가끔 'AttributeError: 'Workbook' object has no attribute 'add_worksheet''라는 오류에 직면할 수 있습니다. 이는 주로 'add_worksheet' 메서드를 호출하려 할 때 발생합니다. 이번 블로그 글에서는 이 오류의 원인과 함께 해결 방법을 알아보겠습니다.

에러 발생 예시 코드

먼저, 'AttributeError: 'Workbook' object has no attribute 'add_worksheet'' 에러가 발생할 수 있는 간단한 코드를 살펴봅시다.

import xlwings as xw

# 새로운 워크북 생성
workbook = xw.Workbook()

# 'add_worksheet' 메서드 사용 시도
worksheet = workbook.add_worksheet('새로운 시트')
print(worksheet)

에러 해결 방법

1. 휴대용 Excel 대신 직접 엑셀 애플리케이션 사용

xlwings에서 'add_worksheet' 메서드는 실제 Excel 애플리케이션이 실행되고 있을 때에만 작동합니다. 따라서, 만약 이 메서드를 호출했을 때 오류가 발생한다면, Excel이 올바르게 실행되고 있는지를 확인해보세요.

import xlwings as xw

# 엑셀 애플리케이션을 호출
app = xw.App(visible=True)
workbook = app.books.add()

# 'add_worksheet' 메서드 사용
worksheet = workbook.sheets.add('새로운 시트')
print(worksheet)

2. 올바른 메서드 사용

'add_worksheet' 메서드는 xlwings의 Workbook 클래스에서 직접 사용할 수 없으므로, 대신 'sheets.add' 메서드를 사용하여 새로운 시트를 추가해야 합니다. 이 점을 주의하세요!

import xlwings as xw

# Excel 애플리케이션을 호출하고 새로운 워크북 생성
app = xw.App(visible=True)
workbook = app.books.add()

# 'sheets.add' 메서드 사용하여 시트 추가
worksheet = workbook.sheets.add('새로운 시트')
print(worksheet)

마무리

이번 블로그 글에서는 xlwings에서 발생할 수 있는 'AttributeError: 'Workbook' object has no attribute 'add_worksheet'' 에러와 그 해결 방법에 대해 살펴보았습니다. 오류를 피하기 위해 Excel 애플리케이션이 실행 중인지 확인하고, 올바른 메서드를 사용하여 시트를 추가하는 것이 매우 중요합니다. 필요한 경우 xlwings의 공식 문서를 참고하며, 효율적으로 엑셀 작업을 자동화하세요!

반응형