如何绕过selenium python web抓取中的错误

如何绕过selenium python web抓取中的错误,python,selenium,web-scraping,Python,Selenium,Web Scraping,我已经为网络扫描编写了以下代码。没有if-else循环部分的代码工作得很好,这是我打算做的。我有一个我想要抓取的url列表,如果在任何url中不存在元素,那么我必须绕过该url并转到下一个。我绕过了没有元素的url,但是我的正常抓取在else循环中无法正常工作。 有人帮忙吗 from selenium import webdriver from selenium.webdriver.common.action_chains import ActionChains import time from

我已经为网络扫描编写了以下代码。没有if-else循环部分的代码工作得很好,这是我打算做的。我有一个我想要抓取的url列表,如果在任何url中不存在元素,那么我必须绕过该url并转到下一个。我绕过了没有元素的url,但是我的正常抓取在else循环中无法正常工作。 有人帮忙吗

from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
import time
from selenium.common.exceptions import TimeoutException
from selenium.common.exceptions import NoSuchElementException  

urls= [
'http://www.marketsmojo.com/Stocks?StockId=1002687&Exchange=0'
]
f= open("lolly.txt","a+")
browser=webdriver.Chrome()
browser.maximize_window()
browser.get('http://www.marketsmojo.com/Stocks?StockId=565016&Exchange=0')
browser.find_element_by_xpath("//*[@id='step-0']/a/i").click()
for url in urls:
    browser.get(url)
    browser.execute_script("window.scrollTo(10,9500);")
    browser.implicitly_wait(2000)
    if browser.find_element_by_xpath("//div[contains(.,' No Shareholding data available ')]"):
        continue
    else:
        add=browser.find_element_by_css_selector('#btnShareholdingDashboardFullDetails')
        SearchButton = browser.find_element_by_css_selector('#btnShareholdingDashboardFullDetails')
        Hover = ActionChains(browser).move_to_element(add).move_to_element(SearchButton)
        Hover.click().perform()
        browser.find_elements_by_css_selector('#allquarters > div > table')
        add1 = browser.find_element_by_css_selector('#AllQuarters')
        SearchButton1 = browser.find_element_by_css_selector('#AllQuarters')
        Hover1 = ActionChains(browser).move_to_element(add).move_to_element(SearchButton1)
        Hover1.click().perform()
        data = []
        for tr in browser.find_elements_by_css_selector('#allquarters > div > table'):
            ths = tr.find_elements_by_tag_name('th')
            tds = tr.find_elements_by_tag_name('td')
            if ths: 
                data.append([th.text for th in ths])
            if tds: 
                data.append([td.text for td in tds])
            f.write(str(data))


browser.quit()

抱歉给你们添麻烦了,只是超时功能导致了打嗝。!
代码非常好。

如果它停止时没有错误,这意味着没有错误,只是它的工作方式与您认为的不一样。请发布错误got@Arount:没有错误,没错,但是else块根本不会执行。!url被点击,网页将永久保留。问题真的不清楚。@GaurangShah很抱歉我的英语部分。!希望现在一切都会好起来?