Lazulitecn 2021-04-22 14:58 采纳率: 84.8%
浏览 432
已结题

Python xlrd,在循环读取行数时,遇到最后一行空白单元格时报错

rownum = 1
while True:
    getrow = table.cell(rownum, 5).value
    print(getrow)
    if len(getrow) > 0:
        rownum += 1
        print(rownum)
    else:
        break
print(rownum)

为了获取表格行数,在循环最后一行遇到空白单元格时,getrow = table.cell(rownum, 5).value报错,没有办法到达后面的if判断

self._cell_types[rowx][colx],

IndexError: list index out of range

  • 写回答

1条回答 默认 最新

  • 爱晚乏客游 2021-04-22 15:01
    关注

    报错是指你的数组越界。下标从0开始的,也就是说,rows和cols的0代表的是第一行第一列,如果你是一行数据,那么你的table.cell(rownum-1,5)而不是rownum,如果cols=5,那么你读取第五个应该是table.cell(rownum-1,4)

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 8月6日

悬赏问题

  • ¥15 公司的电脑,win10系统自带远程协助,访问家里个人电脑,提示出现内部错误,各种常规的设置都已经尝试,感觉公司对此功能进行了限制(我们是集团公司)
  • ¥15 救!ENVI5.6深度学习初始化模型报错怎么办?
  • ¥30 eclipse开启服务后,网页无法打开
  • ¥30 雷达辐射源信号参考模型
  • ¥15 html+css+js如何实现这样子的效果?
  • ¥15 STM32单片机自主设计
  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多
  • ¥50 求一个win系统下运行的可自动抓取arm64架构deb安装包和其依赖包的软件。