您的位置: 网站首页> selenium爬虫> 当前文章
selenium通过js定位元素及元素赋值
老董-我爱我家房产SEO2020-09-14177围观,103赞
selenium可以执行js代码,只需要一句话即可:
driver.execute_script('js代码')
鉴于这个特点我们就可以利用js来操作元素比如实现元素定位、输出文字等,但是前提是对js的DOM操作有所了解,对以下方法不陌生:
document.getElementById("id") document.getElementsByName("Name") -----(获取的是list) document.getElementsByTagName("tag") -----(获取的是list) document.getElementsByClassName("class") -----(获取的是list)IE8及其以下版本的浏览器未实现getElementsByClassName方法 document.querySelector("css selector") -----(获取的是单个元素) document.querySelectorAll("css selector") -----(获取的是元素list)
以天眼查这个垃圾网站为例为,来完成以下步骤
1、打开天眼查,
2、定位到输入框,输入垃圾seo;
3、定位到搜索按钮,点击搜索
与上一篇不同的是在第2步我们可以通过js来定位输入框且输入元素。具体代码如下:
# -*- coding: utf-8 -*- import time 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 from selenium.webdriver.chrome.options import Options def go_click(url): try: driver.get(url) # 加载到底部 bottom = WebDriverWait(driver, 15).until( EC.presence_of_element_located((By.CLASS_NAME, "friendly-title")) ) # 通过js获取搜索框输入文字 input_js = 'document.getElementById("home-main-search").value="垃圾seo"' # 执行js driver.execute_script(input_js) # xpath定位 显式等待 button = WebDriverWait(driver, 15).until( EC.element_to_be_clickable((By.XPATH, "//*[@id='web-content']/div/div[1]/div[2]/div/div/div[2]/div[2]/div[1]/div/span")) ) button.click() except Exception as e: print(e) else: print("ok") finally: time.sleep(10) driver.quit() if __name__ == "__main__": driver = webdriver.Chrome() driver.maximize_window() go_click("https://www.tianyancha.com/")
很赞哦!
python编程网提示:转载请注明来源www.python66.com。
有宝贵意见可添加站长微信(底部),获取技术资料请到公众号(底部)。同行交流请加群
相关文章
文章评论
-
selenium通过js定位元素及元素赋值文章写得不错,值得赞赏
站点信息
- 网站程序:Laravel
- 客服微信:a772483200