我尝试获取
的内容<span class="noactive">0 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()的东西,但是由于任何原因我都无法得到他们工作)。
答案 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