如何使用 Python 将 .xlsm(启用宏的 excel 文件)转换为 .xlsx?

Mah*_*ita 4 windows excel xlsx python-2.7 xlsm

我正在尝试将 .xlsm 文件中的数据作为数据框导入。当我使用下面的命令导入 .xlsm 文件时,它给了我一个空的数据帧作为结果:

exp = pd.read_excel(File_Path+'file_name'.xlsx',sheetname='Data',header=None)
Run Code Online (Sandbox Code Playgroud)

我手动将 .xlsm 文件保存为 .xlsx 文件并将它们作为数据框导入。

有人能告诉我如何使用 Python 将 .xlsm 文件另存为 .xlsx 吗?

Mar*_*ans 5

我建议您尝试使用win32com类型方法。如果你在 Windows 上,你可以使用 Python 来自动化 Excel 本身来执行从.xlxm文件到.xlsx格式的转换。然后可以使用通常的 Pandaspd.read_excel()函数正确读取该文件。

这可以按如下方式完成:

import win32com.client as win32

excel = win32.gencache.EnsureDispatch('Excel.Application')

# Load the .XLSM file into Excel
wb = excel.Workbooks.Open(r'input.xlsm')

# Save it in .XLSX format to a different filename
excel.DisplayAlerts = False
wb.DoNotPromptForConvert = True
wb.CheckCompatibility = False
wb.SaveAs(r"output.xlsx", FileFormat=51, ConflictResolution=2)
excel.Application.Quit()

# Load the .XLSX file into Pandas
df = pd.read_excel('output.xlsx', sheetname='Data', header=None)
Run Code Online (Sandbox Code Playgroud)

我建议您为文件名添加完整路径。