我找不到如何使用硒python获取文本

时间:2019-08-08 15:34:51

标签: python-3.x selenium web

我尝试获取

的内容
<span class="noactive">0&nbsp;Jours restants</span>

(这是保修的到期日期) 但我不知道该如何获取(我需要将其打印在文件中)

我的代码

def scrapper_lenovo(file, line):
   CHROME_PATH = 'C:\Program Files (x86)\Google\Chrome\Application\chrome.exe'
   CHROMEDRIVER_PATH = 'C:\webdriver\chromedriver'
   WINDOW_SIZE = "1920,1080"
   chrome_options = Options()  
   chrome_options.add_argument("--headless")
   chrome_options.add_argument("--window-size=%s" % WINDOW_SIZE)
   chrome_options.binary_location = CHROME_PATH
   d = driver.Chrome(executable_path=CHROMEDRIVER_PATH,
                          chrome_options=chrome_options)  
   d.get("https://pcsupport.lenovo.com/fr/fr/warrantylookup")
   search_bar = d.find_element_by_xpath('//*[@id="input_sn"]')
   search_bar.send_keys(line[19])
   search_bar.send_keys(Keys.RETURN)
   time.sleep(4)
   try:
      warrant = d.find_element_by_xpath('//*[@id="W-Warranties"]/section/div/div/div[1]/div[1]/div[1]/p[1]/span')
      file.write(warrant)
   except:
      print ("test")
      pass
   if ("In Warranty" not in d.page_source):
    file.write(line[3])
    file.write("\n")
   d.close()

我尽力看到可以打印出“保证书”的内容,但是我找不到任何允许它的功能(我看到了一些使用.text()、. gettext()的东西,但是由于任何原因我都无法得到他们工作)。

1 个答案:

答案 0 :(得分:-1)

您可以尝试与所需标签明确匹配,the relevant XPath expression为:

//span[@class='noactive']

我还建议您使用此time.sleep()函数,它是某种形式的性能反模式,如果您需要等待某个元素的存在/可见性/不可见/不存在,则应该使用{ {3}}

因此删除这些行:

time.sleep(4)
warrant = d.find_element_by_xpath('//*[@id="W-Warranties"]/section/div/div/div[1]/div[1]/div[1]/p[1]/span')

,并改用此版本:

warrant = WebDriverWait(driver, 10).until(expected_conditions.presence_of_element_located((By.XPATH, "//span[@class='noactive']")))

更多信息:Explicit Wait