Selenium Python 3.4.3 自动洪流:Link 部分
Selenium Python 3.4.3 Automatic Torrenting: Link section
我想做的是制作一个简单的程序,让我 运行 它基本上进入 Torrentz 并遵循一些 link 最终能够通过 uttorent 下载文件。下面是我到目前为止编写的代码,我似乎无法使变量 linkElem
工作。而且我似乎也无法使 linkElem.find_elements_by_xpath
达到 link 的必要性。如果您认为自己知道出了什么问题,请提供帮助。
谢谢。
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
browser = webdriver.Firefox()
browser.get('https://torrentz.eu/')
searchElem = browser.find_element_by_id('thesearchbox')
searchElem.send_keys('Limitless')
searchButton = browser.find_element_by_id('thesearchbutton')
searchButton.click()
linkElem = linkElem.find_elements_by_xpath("//div[@class='results']//a[@href='/9ea0c575520a3065d85b285c9474231192368db7']")
#wait = WebDriverWait(browser, 6)
#linkElem = wait.until(EC.visibility_of_element_located((By.href, "/9ea0c575520a3065d85b285c9474231192368db7")))
#linkElem.clear()
#linkElem = browser.find_element_by_link_text('S01E20 HDTV x264 LOL ettv')
#linkElem.click()
#SignIn = browser.find_elements_by_id('signIn')
#SignIn.click()
#passwordElem.submit()
我认为您不能也不应该依赖 href
属性值。相反,从搜索结果容器内的 dl
元素下获取 links。另外,加个等待:
# wait for search results to appear
wait = WebDriverWait(browser, 6)
wait.until(EC.visibility_of_element_located((By.CSS_SELECTOR, "div.results dl")))
links = driver.find_elements_by_css_selector("div.results dl dt a")
links[0].click()
links
在您的例子中将包含所有搜索结果 link,links[0]
是第一个 link。
我想做的是制作一个简单的程序,让我 运行 它基本上进入 Torrentz 并遵循一些 link 最终能够通过 uttorent 下载文件。下面是我到目前为止编写的代码,我似乎无法使变量 linkElem
工作。而且我似乎也无法使 linkElem.find_elements_by_xpath
达到 link 的必要性。如果您认为自己知道出了什么问题,请提供帮助。
谢谢。
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
browser = webdriver.Firefox()
browser.get('https://torrentz.eu/')
searchElem = browser.find_element_by_id('thesearchbox')
searchElem.send_keys('Limitless')
searchButton = browser.find_element_by_id('thesearchbutton')
searchButton.click()
linkElem = linkElem.find_elements_by_xpath("//div[@class='results']//a[@href='/9ea0c575520a3065d85b285c9474231192368db7']")
#wait = WebDriverWait(browser, 6)
#linkElem = wait.until(EC.visibility_of_element_located((By.href, "/9ea0c575520a3065d85b285c9474231192368db7")))
#linkElem.clear()
#linkElem = browser.find_element_by_link_text('S01E20 HDTV x264 LOL ettv')
#linkElem.click()
#SignIn = browser.find_elements_by_id('signIn')
#SignIn.click()
#passwordElem.submit()
我认为您不能也不应该依赖 href
属性值。相反,从搜索结果容器内的 dl
元素下获取 links。另外,加个等待:
# wait for search results to appear
wait = WebDriverWait(browser, 6)
wait.until(EC.visibility_of_element_located((By.CSS_SELECTOR, "div.results dl")))
links = driver.find_elements_by_css_selector("div.results dl dt a")
links[0].click()
links
在您的例子中将包含所有搜索结果 link,links[0]
是第一个 link。