您的位置: 网站首页> selenium教程> 当前文章
selenium通过js定位元素及元素赋值
老董-我爱我家房产SEO2020-09-14178围观,108赞
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定位元素及元素赋值文章写得不错,值得赞赏


