Selenium Driver是在下载大量json数据后ajax调用的一个页面



我有一个类似的代码

driver.find_element_by_xpath("//div[@aria-rowindex=7][@aria-colindex=10]//child::span[1]").click() #click will take me to a new ajax page - no change in url
driver.implicitly_wait(60)
time.sleep(160) #without this the below a.png is still behind before my previous click
driver.save_screenshot('a.png') #new url page is in screenshot properly. 
#working fine until this line
driver.implicitly_wait(60)
print(driver.page_source) #still in old page's page_source and the below xpath is not available here
WebDriverWait(driver, 60).until(EC.element_to_be_clickable((By.XPATH, "//button[@button_id='fuseBlowView']"))).click()

为什么即使屏幕截图显示的是新页面,驱动程序仍然使用我的旧页面?现在它的错误是这样的:

WebDriverWait(driver, 60).until(EC.element_to_be_clickable((By.XPATH, "//button[@button_id='fuseBlowView']"))).click()
File "C:UsersjrexPycharmProjectsDragonvenvlibsite-packagesseleniumwebdriversupportwait.py", line 80, in until
raise TimeoutException(message, screen, stacktrace)
selenium.common.exceptions.TimeoutException: Message:

它找不到xpath,因为旧的页面url仍在driver.page_source中在selenium打开的网络浏览器中,我甚至可以在等待时间点击按钮——我只是试了一下——我做了一张截图来证明这一点。但为什么我的司机落后了?

第一次点击.png后有很多数据进入这就是等待时间的原因。只是为了把所有的数据都带进来。我正在使用谷歌Chrome驱动程序。

尝试通过iframes=driver.find_elements_by_tag_name("iframe"(,然后切换到相应的iframe并找到所需的元素并单击。这可能会有所帮助!

相关内容

  • 没有找到相关文章

最新更新