Python爬虫中list index out of range解决方案
在python爬取视频项目中出现list index out of range报错,错误解释为列表的索引分配超出列范围;python有序序列中字符串 str 、列表 list 、元组 tuple按索引取值的时,默认范围为 0 ~ len(有序序列)减1,计数从0开始,最后一位索引则为总长度减去1输入的取值结果不在范围内,则会出现ist index out of range
·
在python爬取视频项目中出现list index out of range错误,错误解释为列表的索引分配超出列范围
代码块如下
def saveData(datalist, savepath):
print("save....")
book = xlwt.Workbook(encoding="utf-8", style_compression=0) # 创建workbook对象
sheet = book.add_sheet('豆瓣电影Top250', cell_overwrite_ok=True) # 创建工作表
col = ("电影详情链接", "图片链接", "影片中文名", "影片外国名", "评分", "评价数", "概况", "相关信息")
for i in range(0, 8):
sheet.write(0, i, col[i]) # 列名
for i in range(0, 250):
print("第%d条" % (i + 1))
data = datalist[i]
for j in range(0, 8):
sheet.write(i + 1, j, data[j])
book.save(savepath)
问题解决:
python有序序列中字符串 str 、列表 list 、元组 tuple按索引取值的时,默认范围为 0 ~ len(有序序列)减1,计数从0开始,最后一位索引则为总长度减去1,也可使用负数表示从倒数个数,计数从-1开始,对于有序序列,总体范围为 -len(有序序列) ~ len(有序序列)减1。如果输入的取值结果不在范围内,则会出现ist index out of range。
同时当list为空时,使用list【0】也会出现index超出范围的错误
解决办法:检查索引是否在 -len(有序序列) ~ len(有序序列)减1 范围内
经调试验证,j=7(序列长度-1)时,影视信息成功爬取,且未出现list index out of range错误
后将for循环中i与j的取值范围(0,8)改为(0,7),错误解除程序正常运行
更多推荐
已为社区贡献1条内容
所有评论(0)