본문 바로가기
Python/xlwings

xlwings FileExistsError: File already exists 오류 해결하기

by PySun 2024. 12. 14.
반응형

소개

xlwings을 사용할 때 'FileExistsError: File already exists' 오류는 꽤 일반적인 문제입니다. 이 에러는 새로운 엑셀 파일을 작성하려 할 때, 같은 이름의 파일이 이미 존재하는 경우 발생합니다. 이 블로그 글에서는 이 오류의 원인과 해결 방법을 알아보겠습니다.

에러 발생 예시 코드

먼저, 'FileExistsError'가 발생할 수 있는 간단한 예시 코드를 살펴봅시다.

import xlwings as xw

# 새로운 엑셀 앱의 인스턴스 생성
app = xw.App(visible=True)

# 기존에 같은 이름으로 된 파일 생성
file_path = 'example.xlsx'
wb = xw.Book(file_path)  # 해당 파일이 이미 존재하면 오류 발생

에러 해결 방법

1. 파일 존재 여부 확인 후 열기

파일을 열기 전에 해당 파일이 존재하는지 확인하는 것이 좋습니다. 아래 코드는 파일 존재 여부를 체크하고, 파일이 없다면 새로 생성합니다.

import xlwings as xw
import os

# 엑셀 앱의 인스턴스 생성
app = xw.App(visible=True)

# 파일 경로 설정
file_path = 'example.xlsx'

# 파일이 존재하는지 확인
if os.path.exists(file_path):
    print(f"{file_path} 파일이 이미 존재합니다.")
    wb = xw.Book(file_path)  # 기존 파일 열기
else:
    wb = xw.Book()  # 새 엑셀 파일 생성
    wb.save(file_path)  # 파일 저장

2. 파일 이름 변경

새로운 파일을 만들고 싶다면, 다른 이름을 사용해보세요. 다음 코드는 파일 이름에 현재 시간을 추가하여 고유한 이름을 생성합니다.

import xlwings as xw
import datetime

# 엑셀 앱의 인스턴스 생성
app = xw.App(visible=True)

# 현재 날짜와 시간을 기반으로 새로운 파일 이름 생성
current_time = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")
file_path = f'example_{current_time}.xlsx'

# 새 엑셀 파일 생성 및 저장
wb = xw.Book()
wb.save(file_path)
print(f"{file_path} 파일이 생성되었습니다.")

마무리

이 블로그 글에서는 xlwings에서 발생하는 'FileExistsError: File already exists' 오류에 대한 해결 방법을 살펴보았습니다. 파일의 존재 여부를 확인하고, 필요한 경우 파일 이름을 변경함으로써 이 문제를 극복할 수 있습니다. xlwings를 사용할 때는 항상 파일 관리에 신경쓰고, 에러가 발생했을 때의 대처 방법을 익혀두는 것이 중요합니다.

반응형