【Python】Python处理Excel的报错和处理

1 篇文章 0 订阅
1 篇文章 0 订阅

最近在学习Python+Openpyxl,遇到了IndexError: list index out of range,最终发现是生成器使用错误导致的,希望对也在学习python的朋友有所帮助。

错误1:

#打算截取excel文件的片段,打印出来
import openpyxl
book = openpyxl.load_workbook(r"C:\\Users\\vitus\Desktop\\abc.xlsx")  
sheet = book[book.sheetnames[3]]
cell_range = list(sheet.iter_rows(min_row=4,min_col=10, max_col=20, max_row=30))
print(cell_range[4])
print(cell_range[5])
print(cell_range[6])

#只输出的print(cell_range[4])的内容,后两句的print成功输出,报错“IndexError: list index out of range”

错误2:

#使用for循环print输出内容

import openpyxl
book = openpyxl.load_workbook(r"C:\\Users\\vitus\Desktop\\abc.xlsx")  
sheet = book[book.sheetnames[3]]
cell_range = sheet.iter_rows(min_row=4,min_col=10, max_col=20, max_row=30)
for n in range(0,26):
    for m in range(0, 10):
        print(list(cell_range[n][m]))

#还是输出错误“IndexError: list index out of range”

 修正后的代码:

import openpyxl
book = openpyxl.load_workbook(r"C:\\Users\\vitus\Desktop\\abc.xlsx")  
sheet = book[book.sheetnames[3]]
cell_range = list(sheet.iter_rows(min_row=4,min_col=10, max_col=20, max_row=30))
###在这里就创建list(),可以解决问题
for n in range(0,26):
    for m in range(0, 10):
        print(cell_range[n][m]) ###不要在这里用list()

这个错误应该跟生成器的属性相关,更详细的内容,我也在研究,希望各位大牛能跟帖指导指导,不胜感激。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值