编程语言
首页 > 编程语言> > python – 如何将xls转换为xlsx

python – 如何将xls转换为xlsx

作者:互联网

我有一些* .xls(excel 2003)文件,我想将这些文件转换为xlsx(excel 2007).

当我保存文档时,我使用uno python包,
我可以设置过滤器名称:MS Excel 97
但是没有像’MS Excel 2007’那样的过滤器名称,

请帮帮我,如何设置过滤器名称将xls转换为xlsx?

解决方法:

我以前必须这样做.主要思想是使用xlrd模块打开并解析xls文件并编写
使用openpyxl模块将内容内容添加到xlsx文件中.

这是我的代码.注意!它无法处理复杂的xls文件,如果要使用它,应该添加自己的解析逻辑.

import xlrd
from openpyxl.workbook import Workbook
from openpyxl.reader.excel import load_workbook, InvalidFileException

def open_xls_as_xlsx(filename):
    # first open using xlrd
    book = xlrd.open_workbook(filename)
    index = 0
    nrows, ncols = 0, 0
    while nrows * ncols == 0:
        sheet = book.sheet_by_index(index)
        nrows = sheet.nrows
        ncols = sheet.ncols
        index += 1

    # prepare a xlsx sheet
    book1 = Workbook()
    sheet1 = book1.get_active_sheet()

    for row in xrange(0, nrows):
        for col in xrange(0, ncols):
            sheet1.cell(row=row, column=col).value = sheet.cell_value(row, col)

    return book1

标签:xls,xlsx,python,excel,uno
来源: https://codeday.me/bug/20190919/1813204.html