列表索引在python中超出范围

时间:2011-03-15 05:56:35

标签: python excel

import glob
import xlrd

from xlwt import Workbook

wb = Workbook()

for file_name in glob.glob("foo*.xls"):
    wb_orig = xlrd.open_workbook(file_name)
    for ws_orig in wb_orig.sheets():
        ws = wb.add_sheet('{0} {1}'.format(file_name, ws_orig.name))
        for rx in range(ws_orig.nrows):
            for cx in range(ws_orig.ncols):
                ws.write(rx, cx, ws_orig.cell_value(rx,cx))

wb.save("mefoo.xls")

我在很多方面尝试了上面的代码,将多个excel表合并到一个工作簿中........ 此代码将错误视为

Traceback (most recent call last):
  File "E:\my python\Internship\mergestackoverflow.py", line 16, in <module>
    wb.save("mefoo.xls")
  File "C:\Python27\lib\site-packages\xlwt\Workbook.py", line 634, in save
    doc.save(filename, self.get_biff_data())
  File "C:\Python27\lib\site-packages\xlwt\Workbook.py", line 615, in get_biff_data
    self.__worksheets[self.__active_sheet].selected = True
IndexError: list index out of range

请帮我解决错误..

2 个答案:

答案 0 :(得分:7)

唯一可以获得IndexError的方法是输出工作簿中没有工作表。

您需要检查glob.glob("foo*.xls");看起来它没有返回任何文件。

答案 1 :(得分:1)

我发现的解决方案是不在glob中使用绝对路径。

for file_name in glob.glob("C://your//full//path//here//foo*.xls"):
  #population/merging code here

wb.save("mefoo.xls")

至于为什么这解决了这个问题,我不知道。但我希望这有助于某人。