Intellipaat Back

Explore Courses Blog Tutorials Interview Questions
0 votes
2 views
in Python by (45.3k points)

I have some *.xls(excel 2003) files, and I want to convert those files into xlsx(excel 2007).

I use the uno python package, when I save the documents, I can set the Filter name: MS Excel 97 But there is no Filter name like 'MS Excel 2007',

please help me, how can set the the filter name to convert xls to xlsx ?

1 Answer

0 votes
by (16.8k points)

I've had to do this before. The main idea is to use the xlrd module to open and parse a xls file and write the content to a xlsx file using the openpyxl module.

Here's my code. Attention! It cannot handle complex xls files, you should add you own parsing logic if you are going to use it.

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

Related questions

0 votes
0 answers
0 votes
1 answer
asked Dec 10, 2020 in Python by laddulakshana (16.4k points)
0 votes
1 answer
asked Jan 24, 2020 in Python by Rajesh Malhotra (19.9k points)

31k questions

32.8k answers

501 comments

693 users

Browse Categories

...