본문 바로가기
Python/xlwings

xlwings RuntimeError: The workbook is not open 오류 해결하기

by PySun 2024. 12. 22.
반응형

소개

xlwings를 사용하다 보면 종종 'RuntimeError: The workbook is not open'이라는 오류에 마주치게 될 수 있습니다. 이 오류는 xlwings가 엑셀 워크북을 찾거나, 해당 워크북이 현재 열려 있지 않을 때 발생합니다. 본 포스팅에서는 이 오류의 원인과 해결 방법에 대해 알아보겠습니다.

에러 발생 예시 코드

먼저, 'RuntimeError: The workbook is not open' 에러가 발생할 수 있는 간단한 예시 코드를 살펴봅시다.

import xlwings as xw

# 워크북을 열지 않고 시트에 접근 시도
workbook = xw.Book('example.xlsx')
sheet = workbook.sheets['Sheet1']
print(sheet.range('A1').value)

에러 해결 방법

1. 워크북을 명확하게 열어주기

워크북을 연 후에 코드를 실행해야 합니다. xlwings의 경우, 반드시 워크북이 열려 있어야 합니다. 다음 코드와 같이 수정해보세요.

import xlwings as xw

# 워크북 열기
workbook = xw.Book('example.xlsx')

# 특정 시트에 접근
sheet = workbook.sheets['Sheet1']
print(sheet.range('A1').value)

2. 새로운 인스턴스에서 워크북 열기

가끔 이전 인스턴스에서 열린 엑셀 파일과 충돌할 수 있습니다. 새로운 인스턴스에서 워크북을 열어 오류를 해결해보세요.

import xlwings as xw

# 새로운 엑셀 인스턴스로 워크북 열기
app = xw.App(visible=True)
workbook = app.books.open('example.xlsx')

# 시트에 접근
sheet = workbook.sheets['Sheet1']
print(sheet.range('A1').value)

# 앱을 닫기
app.quit()

3. 파일 경로 및 파일 이름 확인하기

파일 이름이나 경로가 잘못되었을 경우에도 오류가 발생합니다. 파일이 올바른 위치에 있는지, 확장자가 정확한지 확인하세요.

import os
import xlwings as xw

# 파일 경로
file_path = 'C:/path/to/your/example.xlsx'

# 파일이 존재하는지 확인
if os.path.exists(file_path):
    workbook = xw.Book(file_path)
    sheet = workbook.sheets['Sheet1']
    print(sheet.range('A1').value)
else:
    print("지정된 경로에 파일이 존재하지 않습니다.")

마무리

이번 포스팅에서는 xlwings에서 발생할 수 있는 'RuntimeError: The workbook is not open' 오류에 대해 자세히 살펴보았습니다. 워크북을 올바르게 열고, 인스턴스를 사용하여 접근하며, 파일 경로를 확인함으로써 이 문제를 해결할 수 있습니다. xlwings와 함께 편리한 엑셀 자동화를 경험해 보세요!

반응형