Не удалось щелкнуть ссылку, используя selenium webdriver в python

Я пытаюсь нажать на ссылку, показанную ниже:

<a class="user" href="/Kevin-Rose" action_mousedown="UserLinkClickthrough" id="__w2_L73qRYl_link" target="_blank"> <span class="matched_term">Kevin Rose</span> </a> 

Я попытался использовать следующий код:

  user = driver.find_element_by_xpath("//a[@class='user'][1]") user.click() 

Я получил следующую ошибку:

ElementNotVisibleException: Сообщение: u'Element в настоящее время не видно и поэтому не может взаимодействовать с '; Трассировки стека:

Как я могу решить эту проблему?

введите описание изображения здесь

2 Solutions collect form web for “Не удалось щелкнуть ссылку, используя selenium webdriver в python”

Проблема в том, что вы находите элемент, пока он еще не существует. Wait .

Вот полный код, от входа в систему, поиск по следующей первой ссылке Kevin Rose :

 from selenium import webdriver from selenium.webdriver.common.by import By from selenium.webdriver.common.keys import Keys from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.support import expected_conditions as EC URL = "http://www.quora.com" EMAIL = 'your email here' PASSWORD = 'your password here' driver = webdriver.Chrome() # can be webdriver.Firefox() in your case driver.get(URL) wait = WebDriverWait(driver, 10) # login form = driver.find_element_by_class_name('regular_login') username = form.find_element_by_name('email') username.send_keys(EMAIL) password = form.find_element_by_name('password') password.send_keys(PASSWORD) login_button = form.find_element_by_xpath('//input[@type="submit" and @value="Login"]') login_button.click() # search search = wait.until(EC.presence_of_element_located((By.XPATH, "//form[@name='search_form']//input[@name='search_input']"))) search.send_keys('Kevin Rose') search.send_keys(Keys.ENTER) # follow the link link = wait.until(EC.presence_of_element_located((By.LINK_TEXT, "Kevin Rose"))) link.click() 

Попробуйте использовать ниже локаторы

 Xpath : "//span[text()='Kevin Rose']" cssSelector : "a[href*='Kevin-Rose'] > span" 

Edit-я

Вот Xpath, чтобы нажать на имя профиля Kevin Rose

 "//div[contains(.,'Profile:') and contains(@class,'photo')]/span/a//span[text()='Kevin Rose']" 
  • Функция parse () python scrapy (), где возвращается возвращаемое значение?
  • Запуск scrapy от скрипта (новичок)
  • Сканирование, которое не работает на веб-сайте ASPX
  • lxml classic: получить текстовый контент, за исключением вложенных тегов?
  • Является ли порожденный подпроцесс рассмотренным новым динамиком на Heroku?
  • как получить доступ к моему 127.0.0.1:8000 из Android-планшета
  • Django: динамически добавлять приложения в качестве плагина, автоматически создавать URL-адреса и другие настройки
  • Scrapy. Как изменить настройки паука после начала сканирования?
  • порядок URL-адресов Scrapy Crawling с длинным списком start_urls и URL-адресов yiels от паука
  • Django не может найти статические файлы. Нужна вторая пара глаз, я схожу с ума
  • Ошибка lxml «IOError: Ошибка чтения файла» при анализе facebook mobile в скрипте скрепера python
  • Python - лучший язык программирования в мире.