当前位置: 首页 > news >正文

掌握Selenium4:详解各种定位方式

Selenium4中有多种元素定位方式,主要包括以下几种:

  1. 通过ID属性定位:根据元素的id属性进行定位。
  2. 通过name属性定位:当元素没有id属性而有name属性时,可以使用name属性进行元素定位。
  3. 通过class name定位:可以根据元素的class属性进行定位。
  4. 通过tag name定位:根据HTML标签名进行定位。
  5. 通过link text定位:根据链接的文本内容进行定位。
  6. 通过partial link text定位:根据链接的部分文本内容进行定位。
  7. 通过css selector定位:根据CSS选择器规则进行定位。
  8. 通过xpath定位:根据XPath表达式进行定位。

分别对应by方法的:

class By:"""Set of supported locator strategies."""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"

示例:

from selenium import webdriver
from selenium.webdriver.common.by import By
from time import sleepclass TestCase(object):def __init__(self):# 初始化方法,创建一个Chrome浏览器实例并打开百度首页。self.driver = webdriver.Chrome()self.driver.get("https://www.baidu.com/")self.driver.maximize_window()  # 窗口最大化sleep(1)def test_id(self):'''通过ID定位搜索框,输入"selenium"并点击搜索按钮。:return:'''element = self.driver.find_element(by=By.ID, value="kw")element.send_keys("selenium")print(type(element))self.driver.find_element(by=By.ID, value="su").click()sleep(3)# self.driver.quit()def test_name(self):'''通过NAME定位搜索框,输入"selenium"并点击搜索按钮。:return:'''element = self.driver.find_element(by=By.NAME, value="wd")element.send_keys("selenium")print(type(element))self.driver.find_element(by=By.ID, value="su").click()sleep(3)self.driver.quit()def test_link_text(self):'''通过链接文本定位百度首页并点击。:return:'''self.test_id()self.driver.find_element(By.LINK_TEXT, value="百度首页").click()sleep(3)self.driver.quit()def test_partiallink_text(self):'''通过部分链接文本定位百度首页并点击。:return:'''self.test_id()self.driver.find_element(By.PARTIAL_LINK_TEXT, value="首页").click()sleep(3)self.driver.quit()def test_xpath(self):'''通过XPath定位搜索框,输入"selenium"并点击搜索按钮。:return:'''element = self.driver.find_element(by=By.XPATH, value='//*[@id="kw"]')element.send_keys("selenium")print(type(element))self.driver.find_element(by=By.XPATH, value='//*[@id="su"]').click()sleep(3)self.driver.quit()def test_tag(self):'''通过标签名定位input元素。:return:'''element = self.driver.find_element(by=By.TAG_NAME, value='input')print(element)def test_css_selector(self):'''通过CSS选择器定位搜索框,输入"selenium"并点击搜索按钮。:return:'''element = self.driver.find_element(by=By.CSS_SELECTOR, value='#kw')element.send_keys("selenium")print(type(element))self.driver.find_element(by=By.XPATH, value='//*[@id="su"]').click()sleep(3)self.driver.quit()def test_class_name(self):'''通过类名定位搜索框,输入"selenium"并点击搜索按钮。:return: '''element = self.driver.find_element(by=By.CLASS_NAME, value='s_ipt')element.send_keys("selenium")print(type(element))self.driver.find_element(by=By.XPATH, value='//*[@id="su"]').click()sleep(3)self.driver.quit()if __name__ == '__main__':case = TestCase()# case.test_id()# case.test_name()# case.test_link_text()# case.test_partiallink_text()# case.test_xpath()# case.test_tag()# case.test_css_selector()case.test_class_name()

 工具类封装及使用:

from time import sleepfrom selenium import webdriver
from selenium.webdriver.common.by import Bydef get_element(driver,*loc):
# 使用find_element方法查找元素,传入定位方式和定位值e = driver.find_element(*loc)
# 返回找到的元素return eif __name__ == '__main__':driver = webdriver.Chrome()driver.get("https://www.baidu.com/")driver.maximize_window()loc = (By.ID, "kw")get_element(driver,*loc).send_keys("selenium")sleep(10)

http://www.lryc.cn/news/254512.html

相关文章:

  • go-fastfds部署心得
  • Python第三次练习
  • 从Java8升级到Java17,特色优化点
  • js实现富文本
  • 每日OJ题_算法_双指针②_力扣1089. 复写零
  • C++——红黑树
  • 【神化世界】asp网页500内部服务器错误的解决方法
  • java面试题6
  • (03)vite 处理 css
  • 阿里云上传文件出现的问题解决(跨域设置)
  • 利用JavaFX生成验证码图片
  • 6-55.汽车类的继承
  • SCI论文——respectively用法
  • 解决方案 | 法大大电子签约加速农牧业数字化进程
  • 设计模式之GoF23介绍
  • UDP协议实现群聊
  • lombok原理 @Slf4j 怎么生成get set log
  • 【目标检测】进行实时检测计数时,在摄像头窗口显示实时计数个数
  • SpringBoot第56讲:SpringBoot集成文件 - 集成EasyExcel之Excel导入导出
  • python3安装lifelines
  • shell命令学习(1)——(待完善)
  • 机器的深度强化学习算法可以被诱导
  • 学生成绩管理系统(Java)
  • Modbus数据采集模块是什么?
  • 【网络安全】下载并安装 kali 的虚拟机 版本
  • JREBEL 热部署原理
  • 履带吊,笔记
  • WPF转换器Convert
  • 【刷题】【力扣牛客】反转链表的五种方式——Java
  • 使用Java网络编程,窗口,线程,IO,内部类等实现多人在线聊天1.0