news 2026/3/17 4:20:20

Python—selenium —xpath定位方法详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python—selenium —xpath定位方法详解

前言

今天我们来聊聊selenium-- xpath定位方法,我们都知道selenium有八大定位策略分别是id、name、class name、tag name、link text、partial link text、xpath、css 。那么我们今天呢主要来讲讲八大定位策略中的xpath的定位方法,废话不多说我们直接开始吧。下面主要介绍一下xpath:

一、xpath基本定位用法

1.1 使用id定位 -- driver.find_element_by_xpath('//input[@id="kw"]')

1.2 使用class定位 -- driver.find_element_by_xpath('//input[@class="s_ipt"]')

1.3 当然 通过常用的8种方式结合xpath均可以定位(name、tag_name、link_text、partial_link_text)以上只列举了2种常用方式哦。

二、xpath相对路径/绝对路径定位

2.1 相对定位 -- 以// 开头 如://form//input[@name="phone"]

2.2 绝对定位 -- 以/ 开头,但是要从根目录开始,比较繁琐,一般不建议使用 如:/html/body/div/a

三、xpath文本、模糊、逻辑定位

3.1【文本定位】使用text()元素的text内容 如://button[text()="登录"]

3.2 【模糊定位】使用contains() 包含函数 如://button[contains(text(),"登录")]、//button[contains(@class,"btn")] 除了contains不是=等于 多用于display属性

3.3 【模糊定位】使用starts-with -- 匹配以xx开头的属性值;ends-with -- 匹配以xx结尾的属性值 如://button[starts-with(@class,"btn")]、//input[ends-with(@class,"-special")]

3.4 使用逻辑运算符 -- and、or;如://input[@name="phone" and @datatype="m"]

四、xpath轴定位

4.1 轴运算

ancestor:祖先节点 包括父
parent:父节点
preceding-sibling:当前元素节点标签之前的所有兄弟节点
preceding:当前元素节点标签之前的所有节点

following-sibling:当前元素节点标签之后的所有兄弟节点

following:当前元素节点标签之后的所有节点

使用语法: 轴名称 :: 节点名称

使用较多场景:页面显示为一个表格样式的数据列

如:

注意:

#定位 找到元素 -- 做到唯一识别 #优先使用id #舍弃:有下标的出现、有绝对定位的出现、id动态变化时舍弃 from selenium import webdriver import time from selenium.webdriver.support.wait import WebDriverWait from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.common.by import By driver = webdriver.Chrome() driver.get("https://www.baidu.com/") driver.maximize_window() time.sleep(3) # 定位百度搜索框 driver.find_element_by_id("kw").send_keys("python") time.sleep(3) driver.find_element_by_id("su").click() time.sleep(5) # 找到这个元素 ele = driver.find_element_by_xpath('//a[text()="_百度百科"]') # 拖动元素到可见区域--scrollIntoView() 拉到顶部显示,有可能会被导航栏遮挡,定位不到而报错;scrollIntoView(false)可视区域底部对齐 driver.execute_script("arguments[0].scrollIntoView(false);", ele) time.sleep(5) driver.quit()

定位后的常见操作

get(url) 打开网页

send_keys(str) 输入

click() 点击

clear() 清空

text 获取标签文本内容

get_attribute('属性') 获取元素属性值

close() 关闭当前标签页

quit() 关闭浏览器,释放进程

FAQ

  1. 脚本结束如果没有调用quit()方法,chromedriver进程会在后台继续运行。大概占用4M空间。如果创建多了不关,会导致电脑卡。
__import__('os').system("taskkill /f /t /im chromedriver.exe")

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/17 17:35:47

RimSort终极指南:免费开源的RimWorld模组管理器

RimSort终极指南:免费开源的RimWorld模组管理器 【免费下载链接】RimSort 项目地址: https://gitcode.com/gh_mirrors/ri/RimSort RimSort是一款专为RimWorld游戏设计的免费开源模组管理器,支持Windows、Linux和Mac三大操作系统。作为RimPy模组管…

作者头像 李华
网站建设 2026/3/13 12:24:25

Zotero Style终极使用手册:打造高效文献管理系统的10个技巧

作为一名科研工作者,你是否曾为堆积如山的文献感到头疼?面对海量的PDF文档,如何快速定位重要内容、跟踪阅读进度、建立清晰的分类体系?Zotero Style插件正是为解决这些痛点而生,它通过智能可视化和标签管理&#xff0c…

作者头像 李华
网站建设 2026/3/14 4:03:50

Equalizer APO终极指南:解锁专业级音频调校的完整教程

Equalizer APO终极指南:解锁专业级音频调校的完整教程 【免费下载链接】equalizerapo Equalizer APO mirror 项目地址: https://gitcode.com/gh_mirrors/eq/equalizerapo 想要将普通电脑音质提升到专业级别?Equalizer APO正是你需要的音频增强利器…

作者头像 李华
网站建设 2026/3/13 8:58:29

Zotero Style插件:重新定义学术文献管理体验

你是否曾为堆积如山的文献资料感到头疼?在浩瀚的学术海洋中,如何高效管理阅读进度、智能分类研究成果,成为每个研究者面临的共同挑战。Zotero Style插件应运而生,通过创新的可视化界面和智能化标签系统,为学术工作者提…

作者头像 李华
网站建设 2026/3/14 12:24:03

Lumafly模组管理器完整攻略:告别空洞骑士模组安装烦恼

Lumafly模组管理器完整攻略:告别空洞骑士模组安装烦恼 【免费下载链接】Lumafly A cross platform mod manager for Hollow Knight written in Avalonia. 项目地址: https://gitcode.com/gh_mirrors/lu/Lumafly 还在为空洞骑士模组安装的繁琐流程而头疼吗&a…

作者头像 李华
网站建设 2026/3/13 2:24:12

小说下载工具与电子书制作完整指南:打造个人数字图书馆

小说下载工具与电子书制作完整指南:打造个人数字图书馆 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 在数字阅读时代,拥有一款专业的小说下载工具能够…

作者头像 李华