您的位置: 网站首页> selenium爬虫> 当前文章

selenium通过js定位元素及元素赋值

老董2020-09-14157围观,138赞

  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。
有宝贵意见可添加站长微信(底部),获取技术资料请到公众号(底部)。同行交流请加群 python学习会

文章评论

    selenium通过js定位元素及元素赋值文章写得不错,值得赞赏

站点信息

  • 网站程序:Laravel
  • 客服微信:a772483200