Selenium 4.2.0 标签定位8种方法详解

 更新时间:2022年06月16日 08:47:16   作者:BGONE  
这篇文章主要介绍了Selenium 4.2.0 标签定位8种方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

背景

Selenium4使用find_element(by=By.**, value=*)来替换了原来的find_element_by_* 的方法,使用find_elements(by=By.*, value=*)来替换了原来的find_elements_by_* 的方法。

By类定义在 site-packages\selenium\webdriver\common\by.py中:

这就是Selenium4的8种定位方法

元素定位

元素本身是什么:HTML静态页面中的的一个标签
元素定位一般而言是基于元素自身所包含有的特点来进行定位的。
包括:标签的名称(决定元素是什么)、标签的属性(决定元素有什么特质),标签的文本

定位元素的方法

ID = “id”
XPATH = “xpath”
LINK_TEXT = “link text”
PARTIAL_LINK_TEXT = “partial link text”
NAME = “name”
TAG_NAME = “tag name”
CLASS_NAME = “class name”
CSS_SELECTOR = “css selector”

  • id:有ID就用ID定位,基本不会重复
  • name:有name可以考虑用,name类似于人的名字,虽然相对少见的值,但是容易重名
  • link text:基于文本定位链接标签
  • partial link text:类似于SQL中的like%,模糊查找
  • tag name:基于标签名称来查找元素,大概率有多个结果,一般用于查找多个重复的内容的时候使用。
  • class:基于class属性进行元素查找,非必要不推荐,重复率高
  • css selector:定位界万金油,有自己的独特语法,定位语法麻烦,基于标签的class内容进行定位,使用copy
  • selector确定位置

xpath:定位界万金油,有自己的独特语法,定位速度慢,基于树状结构形态定位,使用Copy XPath, Copy full
XPath来确定位置

总结:有id用id,没id用name,都不行用css/xpath,链接可以用link text。find_element元素定位如果同时有多个结果,默认返回定位的第一个结果;find_elements元素定位返回一个列表

实例

测试目的

测试Selenium4的8种元素定位方法

ID、CSS_SELECTOR

输入栏输入yoga,点击搜索

实例网站

京东

实例代码

import time
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Service
service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe")
driver = webdriver.Chrome(service=service)
driver.get(url="https://www.jd.com/")
# id
driver.find_element(by=By.ID,value="key").send_keys("yoga")
# css selector
driver.find_element(by=By.CSS_SELECTOR,value="#search > div > div.form > button").click()
time.sleep(3)
driver.quit()

结果展示

NAME、LINK_TEXT、PARTIAL_LINK_TEXT

用NAME元素输入yoga,用LINK_TEXT定位how123,用PARTIAL_LINK_TEXT定位hao123

实例网站

可以自行百度

实例代码

import time
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Service
service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe")
driver = webdriver.Chrome(service=service)
driver.get(url="https://www.baidu.com/")
# id
driver.find_element(by=By.NAME,value="wd").send_keys("yoga")
time.sleep(3)
driver.get(url="https://www.baidu.com/")
# link text
driver.find_element(by=By.LINK_TEXT,value="hao123").click()
time.sleep(3)
# css selector
driver.get(url="https://www.baidu.com/")
driver.find_element(by=By.PARTIAL_LINK_TEXT,value="1").click()
time.sleep(3)
driver.quit()

结果展示

CSS、XPATH

点击热搜第一

实例网站

微博热搜

实例代码

import time
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Service
service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe")
driver = webdriver.Chrome(service=service)
driver.get(url="https://weibo.com/newlogin?tabtype=search&openLoginLayer=0&url=")

time.sleep(6) # Redirect
# css selector
driver.find_element(by=By.CSS_SELECTOR,value="#scroller > div.vue-recycle-scroller__item-wrapper > div:nth-child(2) > div > div > a > div > div > div.woo-box-item-flex").click()
time.sleep(3)

# xpath
driver.get(url="https://weibo.com/newlogin?tabtype=search&openLoginLayer=0&url=")
time.sleep(6)
driver.find_element(by=By.XPATH,value='//*[@id="scroller"]/div[1]/div[2]/div/div/a/div/div/div[1]').click()

time.sleep(3)
driver.quit()

结果展示

CSDN判定图片违规,无法上传

TAG_NAME、CLASS

去除首页作弊通知弹窗

实例平台

豆豆玩

实例代码

import time
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Service
service = Service(executable_path=r"C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe")
driver = webdriver.Chrome(service=service)
driver.get(url="http://doudouwan.com/")
# tag name
el = driver.find_elements(by=By.TAG_NAME,value="a")[83]
# el2 = driver.find_elements(by=By.CLASS_NAME,value='layui-layer-btn0')[0]
# for i in range(len(el)):
#     if el[i] == el2:
#         print(i)
time.sleep(3)
# delete all cookies in this website, and do not need to refresh driver
driver.delete_all_cookies()
# xpath
driver.get(url="http://doudouwan.com/")
time.sleep(6)
driver.find_elements(by=By.CLASS_NAME,value='layui-layer-btn0')[0].click()
time.sleep(3)
driver.quit()

结果展示

到此这篇关于Selenium 4.2.0 标签定位8种方法的文章就介绍到这了,更多相关Selenium标签定位内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python中的reduce内建函数使用方法指南

    python中的reduce内建函数使用方法指南

    python中的reduce内建函数是一个二元操作函数,他用来将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给reduce中的函数 func()(必须是一个二元操作函数)先对集合中的第1,2个数据进行操作,得到的结果再与第三个数据用func()函数运算,最后得到一个结果
    2014-08-08
  • python科学计算之scipy——optimize用法

    python科学计算之scipy——optimize用法

    今天小编就为大家分享一篇python科学计算之scipy——optimize用法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • Python实现获取内网IP地址的方法总结

    Python实现获取内网IP地址的方法总结

    这篇文章主要为大家详细介绍了五种利用Python语言实现获取内网IP地址的方法,文中的示例代码讲解详细,具有一定的参考价值,需要的可以了解一下
    2023-03-03
  • Python 进程操作之进程间通过队列共享数据,队列Queue简单示例

    Python 进程操作之进程间通过队列共享数据,队列Queue简单示例

    这篇文章主要介绍了Python 进程操作之进程间通过队列共享数据,队列Queue,结合实例形式分析了Python进程数据共享、队列数据处理相关操作技巧,需要的朋友可以参考下
    2019-10-10
  • MATLAB中text函数使用的语法与示例代码

    MATLAB中text函数使用的语法与示例代码

    text函数的功能是向数据点添加文本说明,下面这篇文章主要给大家介绍了关于MATLAB中text函数使用的语法与示例的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • Python如何优雅获取本机IP方法

    Python如何优雅获取本机IP方法

    这篇文章主要介绍了Python如何优雅获取本机IP方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • python 输出列表元素实例(以空格/逗号为分隔符)

    python 输出列表元素实例(以空格/逗号为分隔符)

    今天小编就为大家分享一篇python 输出列表元素实例(以空格/逗号为分隔符),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • 如何将json数据转换为python数据

    如何将json数据转换为python数据

    这篇文章主要介绍了如何将json数据转换为python数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • 教你用Python按顺序读取文件夹中文件

    教你用Python按顺序读取文件夹中文件

    最近工作中读取文件时经常遇上比较复杂的情况,所以下面这篇文章主要给大家介绍了关于如何利用Python按顺序读取文件夹中文件的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • python实现简单聊天功能

    python实现简单聊天功能

    这篇文章主要为大家详细介绍了python实现简单聊天功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07

最新评论