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

How to convert .xlsm (macro enabled excel file) to .xlsx using Python?

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

exp = pd.read_excel(File_Path+'file_name'.xlsx',sheetname='Data',header=None)

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

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

我建议您尝试使用 win32com 类型的方法。如果您使用 Windows,您可以使用 Python 来自动执行 Excel 本身以执行从 .xlxm 文件到 .xlsx 格式的转换。然后可以使用通常的 Pandas pd.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)

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