使用Python進(jìn)行Excel文件xls/xlsx/xsv格式互相轉(zhuǎn)換
1. Excel文件處理 - 將xls文件轉(zhuǎn)換為xlsx
準(zhǔn)備環(huán)境
Python版本需要為3.8-3.14(pywin32的要求)
通過pip下載pywin32:
pip install pywin32
復(fù)制即可運(yùn)行的完整代碼
import os
from win32com import client as wc
def convert_xls_to_xlsx(xls_path: str) -> str:
"""
將單個xls文件轉(zhuǎn)換為xlsx格式,并返回轉(zhuǎn)換后的文件路徑
Args:
xls_path (str): xls文件路徑
Returns:
str: 轉(zhuǎn)換后的xlsx文件路徑
Raises:
FileNotFoundError: 如果文件不存在
ValueError: 如果文件不是xls格式或路徑無效
Exception: 轉(zhuǎn)換過程中的其他錯誤
"""
# 參數(shù)驗(yàn)證
if not xls_path or not isinstance(xls_path, str):
raise ValueError("文件路徑不能為空且必須是字符串")
# 檢查文件是否存在
if not os.path.exists(xls_path):
raise FileNotFoundError(f"文件不存在: {xls_path}")
# 檢查文件擴(kuò)展名
if not xls_path.lower().endswith('.xls'):
raise ValueError(f"文件不是xls格式: {xls_path}")
# 檢查文件是否被占用(臨時文件)
if os.path.basename(xls_path).startswith('~'):
raise ValueError(f"文件可能是臨時文件: {xls_path}")
# 檢查文件大?。ū苊馓幚砜瘴募驌p壞文件)
file_size = os.path.getsize(xls_path)
if file_size == 0:
raise ValueError(f"文件為空: {xls_path}")
excel = None
workbook = None
try:
# 創(chuàng)建Excel應(yīng)用實(shí)例
excel = wc.Dispatch("Excel.Application")
excel.Visible = False
excel.DisplayAlerts = False # 不顯示警告對話框
# 打開工作簿
workbook = excel.Workbooks.Open(xls_path)
# 生成新的xlsx文件路徑
base_path = os.path.splitext(xls_path)[0]
new_path = base_path + ".xlsx"
# 處理文件名沖突
count = 0
while os.path.exists(new_path):
count += 1
new_path = f"{base_path}({count}).xlsx"
# 保存為xlsx格式(51代表xlsx格式)
workbook.SaveAs(new_path, 51)
# 驗(yàn)證轉(zhuǎn)換后的文件
if not os.path.exists(new_path):
raise Exception("轉(zhuǎn)換后的文件未創(chuàng)建成功")
# 檢查轉(zhuǎn)換后的文件大小
if os.path.getsize(new_path) == 0:
raise Exception("轉(zhuǎn)換后的文件為空")
return new_path
except Exception as e:
# 清理可能創(chuàng)建的部分文件
if 'new_path' in locals() and os.path.exists(new_path):
try:
os.remove(new_path)
except:
pass
raise e
finally:
# 確保資源被正確釋放
try:
if workbook:
workbook.Close()
except:
pass
try:
if excel:
excel.Quit()
except:
pass
def main():
"""主函數(shù):轉(zhuǎn)換單個文件并顯示結(jié)果"""
# 直接在代碼中設(shè)置要轉(zhuǎn)換的文件路徑
xls_file_path = r"D:\excel_files\example.xls" # 修改為您要轉(zhuǎn)換的xls文件路徑
try:
print(f"開始轉(zhuǎn)換文件: {xls_file_path}")
# 轉(zhuǎn)換文件
xlsx_path = convert_xls_to_xlsx(xls_file_path)
# 輸出成功信息
print("\n" + "="*50)
print("? 文件轉(zhuǎn)換成功!")
print(f"原始文件: {xls_file_path}")
print(f"轉(zhuǎn)換后文件: {xlsx_path}")
print(f"文件大小: {os.path.getsize(xlsx_path)} 字節(jié)")
print("="*50)
except FileNotFoundError as e:
print(f"? 錯誤: {e}")
print("請檢查文件路徑是否正確")
except ValueError as e:
print(f"? 錯誤: {e}")
print("請確保文件是有效的xls文檔")
except Exception as e:
print(f"? 轉(zhuǎn)換失敗: {e}")
print("可能是Excel應(yīng)用問題或文件損壞")
if __name__ == "__main__":
main()
將代碼復(fù)制到你的Python編輯器中,并修改D:\excel_files\example.xls為您需要轉(zhuǎn)換的xls文件路徑即可。轉(zhuǎn)換后的xlsx文件與xls文件同名(如果已經(jīng)存在了同名xlsx文件,將加上(count)后綴以避免沖突)
核心功能代碼
xls文件轉(zhuǎn)換為xlsx文件的核心功能代碼為:
import os
from win32com import client as wc
excel = wc.Dispatch("Excel.Application")
excel.Visible = False
excel.DisplayAlerts = False
workbook = excel.Workbooks.Open(xls_path)
workbook.SaveAs(new_path, 51)
workbook.Close()
excel.Quit()
將xls_path對應(yīng)的Excel工作簿轉(zhuǎn)換為new_path對應(yīng)的Excel工作簿。需要注意的是這個代碼本身xls_path可以是xls/xlsx類型的Excel文件路徑,Python代碼本身只是起到了讀取Excel文件的作用。
workbook.SaveAs(file_name, file_format)中file_format這個參數(shù)表示另存為文件的格式。
- 51:
xlOpenXMLWorkbook- 不含宏的xlsx格式 - 52:
xlOpenXMLWorkbookMacroEnabled- 含宏的xlsm格式 - 56:
xlExcel8- Excel 97-2003的xls格式 - 6:
xlCSV- CSV格式 - 62:
xlCSVUTF8- UTF-8編碼的CSV格式 - 22:
xlTextMSDOS- MS-DOS文本格式 - 42:
xlUnicodeText- Unicode文本格式
如果原xls文件包含宏,需要使用52格式保存為xlsm文件。
2. Excel文件處理 - 將xlsx文件轉(zhuǎn)換為xls
準(zhǔn)備環(huán)境和核心功能代碼與項(xiàng)目3相同。
復(fù)制即可運(yùn)行的完整代碼
import os
from win32com import client as wc
def convert_xlsx_to_xls(xlsx_path: str) -> str:
"""
將單個xlsx文件轉(zhuǎn)換為xls格式
Args:
xlsx_path (str): xlsx文件路徑
Returns:
str: 轉(zhuǎn)換后的xls文件路徑
"""
if not os.path.exists(xlsx_path):
raise FileNotFoundError(f"文件不存在: {xlsx_path}")
if not xlsx_path.lower().endswith('.xlsx'):
raise ValueError(f"文件不是xlsx格式: {xlsx_path}")
excel = None
workbook = None
try:
excel = wc.Dispatch("Excel.Application")
excel.Visible = False
excel.DisplayAlerts = False
workbook = excel.Workbooks.Open(xlsx_path)
base_path = os.path.splitext(xlsx_path)[0]
new_path = base_path + ".xls"
count = 0
while os.path.exists(new_path):
count += 1
new_path = f"{base_path}({count}).xls"
# 56: xlExcel8 (Excel 97-2003格式)
workbook.SaveAs(new_path, 56)
return new_path
finally:
if workbook:
workbook.Close()
if excel:
excel.Quit()
def main():
xlsx_file_path = r"D:\excel_files\example.xlsx" # 修改為您的xlsx文件路徑
try:
print(f"開始轉(zhuǎn)換文件: {xlsx_file_path}")
xls_path = convert_xlsx_to_xls(xlsx_file_path)
print(f"? 轉(zhuǎn)換成功: {xls_path}")
except Exception as e:
print(f"? 轉(zhuǎn)換失敗: {e}")
if __name__ == "__main__":
main()
將代碼復(fù)制到你的Python編輯器中,并修改D:\excel_files\example.xlsx為您需要轉(zhuǎn)換的xlsx文件路徑即可。轉(zhuǎn)換后的xls文件與xlsx文件同名(如果已經(jīng)存在了同名xls文件,將加上(count)后綴以避免沖突)
3. Excel文件處理 - 將xls文件轉(zhuǎn)換為csv
準(zhǔn)備環(huán)境和核心功能代碼與項(xiàng)目3相同。
復(fù)制即可運(yùn)行的完整代碼
import os
from win32com import client as wc
def convert_xls_to_csv(xls_path: str) -> str:
"""
將單個xls文件轉(zhuǎn)換為csv格式
Args:
xls_path (str): xls文件路徑
Returns:
str: 轉(zhuǎn)換后的csv文件路徑
"""
if not os.path.exists(xls_path):
raise FileNotFoundError(f"文件不存在: {xls_path}")
if not xls_path.lower().endswith('.xls'):
raise ValueError(f"文件不是xls格式: {xls_path}")
excel = None
workbook = None
try:
excel = wc.Dispatch("Excel.Application")
excel.Visible = False
excel.DisplayAlerts = False
workbook = excel.Workbooks.Open(xls_path)
base_path = os.path.splitext(xls_path)[0]
new_path = base_path + ".csv"
count = 0
while os.path.exists(new_path):
count += 1
new_path = f"{base_path}({count}).csv"
# 6: xlCSV (CSV格式)
workbook.SaveAs(new_path, 6)
return new_path
finally:
if workbook:
workbook.Close()
if excel:
excel.Quit()
def main():
xls_file_path = r"D:\excel_files\example.xls" # 修改為您的xls文件路徑
try:
print(f"開始轉(zhuǎn)換文件: {xls_file_path}")
csv_path = convert_xls_to_csv(xls_file_path)
print(f"? 轉(zhuǎn)換成功: {csv_path}")
except Exception as e:
print(f"? 轉(zhuǎn)換失敗: {e}")
if __name__ == "__main__":
main()
將代碼復(fù)制到你的Python編輯器中,并修改D:\excel_files\example.xls為您需要轉(zhuǎn)換的xls文件路徑即可。轉(zhuǎn)換后的csv文件與xls文件同名(如果已經(jīng)存在了同名csv文件,將加上(count)后綴以避免沖突)
4. Excel文件處理 - 將xlsx文件轉(zhuǎn)換為csv
準(zhǔn)備環(huán)境和核心功能代碼與項(xiàng)目3相同。
復(fù)制即可運(yùn)行的完整代碼
import os
from win32com import client as wc
def convert_xlsx_to_csv(xlsx_path: str) -> str:
"""
將單個xlsx文件轉(zhuǎn)換為csv格式
Args:
xlsx_path (str): xlsx文件路徑
Returns:
str: 轉(zhuǎn)換后的csv文件路徑
"""
if not os.path.exists(xlsx_path):
raise FileNotFoundError(f"文件不存在: {xlsx_path}")
if not xlsx_path.lower().endswith('.xlsx'):
raise ValueError(f"文件不是xlsx格式: {xlsx_path}")
excel = None
workbook = None
try:
excel = wc.Dispatch("Excel.Application")
excel.Visible = False
excel.DisplayAlerts = False
workbook = excel.Workbooks.Open(xlsx_path)
base_path = os.path.splitext(xlsx_path)[0]
new_path = base_path + ".csv"
count = 0
while os.path.exists(new_path):
count += 1
new_path = f"{base_path}({count}).csv"
# 6: xlCSV (CSV格式)
workbook.SaveAs(new_path, 6)
return new_path
finally:
if workbook:
workbook.Close()
if excel:
excel.Quit()
def main():
xlsx_file_path = r"D:\excel_files\example.xlsx" # 修改為您的xlsx文件路徑
try:
print(f"開始轉(zhuǎn)換文件: {xlsx_file_path}")
csv_path = convert_xlsx_to_csv(xlsx_file_path)
print(f"? 轉(zhuǎn)換成功: {csv_path}")
except Exception as e:
print(f"? 轉(zhuǎn)換失敗: {e}")
if __name__ == "__main__":
main()
將代碼復(fù)制到你的Python編輯器中,并修改D:\excel_files\example.xlsx為您需要轉(zhuǎn)換的xlsx文件路徑即可。轉(zhuǎn)換后的csv文件與xlsx文件同名(如果已經(jīng)存在了同名csv文件,將加上(count)后綴以避免沖突)
5. Excel文件處理 - 將csv文件轉(zhuǎn)換為xls
準(zhǔn)備環(huán)境和核心功能代碼與項(xiàng)目3相同。
復(fù)制即可運(yùn)行的完整代碼
import os
from win32com import client as wc
def convert_csv_to_xls(csv_path: str) -> str:
"""
將單個csv文件轉(zhuǎn)換為xls格式
Args:
csv_path (str): csv文件路徑
Returns:
str: 轉(zhuǎn)換后的xls文件路徑
"""
if not os.path.exists(csv_path):
raise FileNotFoundError(f"文件不存在: {csv_path}")
if not csv_path.lower().endswith('.csv'):
raise ValueError(f"文件不是csv格式: {csv_path}")
excel = None
workbook = None
try:
excel = wc.Dispatch("Excel.Application")
excel.Visible = False
excel.DisplayAlerts = False
workbook = excel.Workbooks.Open(csv_path)
base_path = os.path.splitext(csv_path)[0]
new_path = base_path + ".xls"
count = 0
while os.path.exists(new_path):
count += 1
new_path = f"{base_path}({count}).xls"
# 56: xlExcel8 (Excel 97-2003格式)
workbook.SaveAs(new_path, 56)
return new_path
finally:
if workbook:
workbook.Close()
if excel:
excel.Quit()
def main():
csv_file_path = r"D:\excel_files\example.csv" # 修改為您的csv文件路徑
try:
print(f"開始轉(zhuǎn)換文件: {csv_file_path}")
xls_path = convert_csv_to_xls(csv_file_path)
print(f"? 轉(zhuǎn)換成功: {xls_path}")
except Exception as e:
print(f"? 轉(zhuǎn)換失敗: {e}")
if __name__ == "__main__":
main()
將代碼復(fù)制到你的Python編輯器中,并修改D:\excel_files\example.csv為您需要轉(zhuǎn)換的csv文件路徑即可。轉(zhuǎn)換后的xls文件與csv文件同名(如果已經(jīng)存在了同名xls文件,將加上(count)后綴以避免沖突)
6. Excel文件處理 - 將csv文件轉(zhuǎn)換為xlsx
準(zhǔn)備環(huán)境和核心功能代碼與項(xiàng)目3相同。
復(fù)制即可運(yùn)行的完整代碼
import os
from win32com import client as wc
def convert_csv_to_xlsx(csv_path: str) -> str:
"""
將單個csv文件轉(zhuǎn)換為xlsx格式
Args:
csv_path (str): csv文件路徑
Returns:
str: 轉(zhuǎn)換后的xlsx文件路徑
"""
if not os.path.exists(csv_path):
raise FileNotFoundError(f"文件不存在: {csv_path}")
if not csv_path.lower().endswith('.csv'):
raise ValueError(f"文件不是csv格式: {csv_path}")
excel = None
workbook = None
try:
excel = wc.Dispatch("Excel.Application")
excel.Visible = False
excel.DisplayAlerts = False
workbook = excel.Workbooks.Open(csv_path)
base_path = os.path.splitext(csv_path)[0]
new_path = base_path + ".xlsx"
count = 0
while os.path.exists(new_path):
count += 1
new_path = f"{base_path}({count}).xlsx"
# 51: xlOpenXMLWorkbook (不含宏的xlsx)
workbook.SaveAs(new_path, 51)
return new_path
finally:
if workbook:
workbook.Close()
if excel:
excel.Quit()
def main():
csv_file_path = r"D:\excel_files\example.csv" # 修改為您的csv文件路徑
try:
print(f"開始轉(zhuǎn)換文件: {csv_file_path}")
xlsx_path = convert_csv_to_xlsx(csv_file_path)
print(f"? 轉(zhuǎn)換成功: {xlsx_path}")
except Exception as e:
print(f"? 轉(zhuǎn)換失敗: {e}")
if __name__ == "__main__":
main()
將代碼復(fù)制到你的Python編輯器中,并修改D:\excel_files\example.csv為您需要轉(zhuǎn)換的csv文件路徑即可。轉(zhuǎn)換后的xlsx文件與csv文件同名(如果已經(jīng)存在了同名xlsx文件,將加上(count)后綴以避免沖突)
以上就是使用Python進(jìn)行Excel文件xls/xlsx/xsv格式互相轉(zhuǎn)換的詳細(xì)內(nèi)容,更多關(guān)于Python文件格式xls/xlsx/xsv互轉(zhuǎn)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python實(shí)現(xiàn)的AES雙向?qū)ΨQ加密解密與用法分析
這篇文章主要介紹了python實(shí)現(xiàn)的AES雙向?qū)ΨQ加密解密與用法,簡單分析了AES加密解密算法的基本概念并結(jié)合實(shí)例形式給出了AES加密解密算法的相關(guān)實(shí)現(xiàn)技巧與使用注意事項(xiàng),需要的朋友可以參考下2017-05-05
Python利用Spire.Presentation?for?Python實(shí)現(xiàn)將PPT(X)?轉(zhuǎn)換為PDF
在日常辦公和自動化場景中,PowerPoint?(PPT/PPTX)?文件因其豐富的表現(xiàn)力而廣泛應(yīng)用于演示和匯報本文將為您詳細(xì)介紹如何使用?Spire.Presentation?for?Python?輕松實(shí)現(xiàn)?PPT?到?PDF?的自動化轉(zhuǎn)換,需要的可以了解下2025-10-10
Python工程實(shí)踐之np.loadtxt()讀取數(shù)據(jù)
為了方便使用和記憶,有時候我們會把numpy.loadtxt()縮寫成np.loadtxt(),這篇文章主要給大家介紹了關(guān)于Python工程實(shí)踐之np.loadtxt()讀取數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2023-07-07
Python調(diào)用C/C++函數(shù)庫的多種方法與實(shí)踐指南
Python作為一門高級編程語言,以其簡潔的語法和豐富的庫生態(tài)贏得了開發(fā)者的青睞,然而,在計(jì)算密集型任務(wù)中,Python的性能往往無法滿足要求,Python調(diào)用C/C++函數(shù)庫成為提升應(yīng)用性能的關(guān)鍵技術(shù)路徑,本文將深入探討Python調(diào)用C/C++函數(shù)庫的多種方法,需要的朋友可以參考下2025-08-08
Python??處理?Pandas?DataFrame?中的行和列
這篇文章主要介紹了Python處理Pandas?DataFrame中的行和列,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09
Python實(shí)現(xiàn)在matplotlib中兩個坐標(biāo)軸之間畫一條直線光標(biāo)的方法
這篇文章主要介紹了Python實(shí)現(xiàn)在matplotlib中兩個坐標(biāo)軸之間畫一條直線光標(biāo)的方法,涉及Python操作matplotlib模塊繪圖的相關(guān)技巧,需要的朋友可以參考下2015-05-05

