python提示list index out of range_python爬虫提醒IndexError: list index out of range

最近在写一个爬虫程序,但是调用main()就不停的提示IndexError: list index out of range

可是在子函数进行测试的时候明明是不存在这个问题的

代码如下

from selenium import webdriver

from lxml import etree

from selenium.webdriver.common.by import By

from selenium.webdriver.support.ui import WebDriverWait

from selenium.webdriver.support import expected_conditions as EC

url='http://www.ipe.org.cn/IndustryRecord/Regulatory.aspx'

driver=webdriver.Chrome()

driver.get(url)

def parse_and_save():

s=driver.page_source

ss=etree.HTML(s)

sss=ss.xpath('//*[@id="table_con0"]/div[2]/table/tbody/tr')

with open(r'C:\Users\xiaot\Desktop\IPE.csv','w',encoding='utf-8') as f:

for tr in sss:

name=tr.xpath('./td')[1].text

location=tr.xpath('./td')[2].text+tr.xpath('./td/span')[0].text

year=tr.xpath('./td')[3].text

records=tr.xpath('./td')[4].text

f.write("{},{},{},{}\n".format(name,location,year,records))

def Page_Turner():

WebDriverWait(driver,60000000).until(EC.presence_of_element_located((By.XPATH,'//*[@id="pagination0"]/div/div/div[3]/i[3]')))

driver.find_element_by_xpath('//*[@id="pagination0"]/div/div/div[1]/select/option[4]').click()

WebDriverWait(driver,60000000).until(EC.presence_of_element_located((By.XPATH,'//*[@id="pagination0"]/div/div/div[3]/i[3]')))

parse_and_save()

driver.find_element_by_xpath('//*[@id="pagination0"]/div/div/div[3]/i[3]').click()

WebDriverWait(driver,60000000).until(EC.presence_of_element_located((By.XPATH,'/html/body/div[5]/div[2]/div[2]/div/div[2]/a')))

code=driver.find_element_by_xpath('/html/body/div[5]/div[2]/div[2]/div/div[2]/a')

if code:

while True:

val=driver.find_element_by_xpath('//*[@id="txtCode"]').get_attribute('value')

if val and len(val)==4:

break

pass

pass

driver.find_element_by_xpath('/html/body/div[5]/div[2]/div[2]/div/div[2]/a').click()

def main():

i=1

for i in range(1,3):

Page_Turner()

i+=1

print('It is done!')

main()

报错类型为

File "C:/Users/ttt.py", line 46, in parse_and_save

name=tr.xpath('./td')[1].text

IndexError: list index out of range

可是我在用Page_Turner()这个函数进行调试的时候就不会报错

请问这是为什么?

是我主函数写的有问题吗?

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
爬虫报错"IndexError: list index out of range"是由于列表索引超出范围导致的错误。这通常发生在尝试访问列表中不存在的索引位置时。为了解决这个问题,你可以采取以下几个步骤: 1. 检查列表的长度:首先,你需要确保列表的长度大于你尝试访问的索引位置。你可以使用len()函数来获取列表的长度,并与你尝试访问的索引位置进行比较。 2. 检查循环边界:如果你在循环中使用索引来访问列表元素,那么你需要确保循环的边界条件正确。例如,如果你使用range()函数来生成索引,你需要确保循环的范围不超过列表的长度。 3. 检查数据源:如果你的数据源不正确或者没有正确加载到列表中,那么你可能会遇到这个错误。你可以检查数据源的加载过程,确保数据正确加载到列表中。 4. 处理异常:如果你确定列表的长度和循环边界都是正确的,但仍然遇到这个错误,那么你可以使用异常处理来捕获并处理这个错误。你可以使用try-except语句来捕获IndexError,并在except块中处理这个错误。 下面是一个处理"IndexError: list index out of range"错误的示例代码: ```python try: # 尝试访问列表中的索引位置 value = my_list[index] # 继续处理其他操作 except IndexError: # 处理IndexError错误 print("Index out of range") ``` 请注意,这只是一个示例代码,你需要根据你的具体情况进行适当的修改和调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值