【问题标题】:How to convert .xlsm (macro enabled excel file) to .xlsx using Python?如何使用 Python 将 .xlsm(启用宏的 excel 文件)转换为 .xlsx?
【发布时间】:2019-07-23 04:50:00
【问题描述】:

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

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

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

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

【问题讨论】:

  • 您需要发布更多代码,或者说明您正在使用哪些库。

标签: excel windows python-2.7 xlsx xlsm


【解决方案1】:

我建议您尝试使用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)

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

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2013-01-25
    • 2020-12-07
    • 1970-01-01
    • 2012-03-15
    • 2023-01-11
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多