selenium之常用定位

这篇博客详细介绍了Selenium如何进行元素定位和操作,包括通过id、class_name、link_text、partial_link_text、tag_name、x_path和css_selector等方法定位元素,以及send_keys、click、clear、submit等操作元素的方法。此外,还讲解了等待技巧、浏览器导航、滚动条操作、键盘和鼠标按键模拟以及处理多组元素的策略。

学习selenium吗大概分为两步,定位,操作。

一.定位元素

id:元素属性之一

class_name:就是class,当多个元素有统一属性时,无法定位到期望元素。要全局唯一

link test:当页面元素是一个链接时,使用链接内容,link test定位它。

partial link test:使用部分内容定位链接,同样保证部分内容的唯一性。

tag_name:标签名,div,img,input等都属于

x_path:组成这个元素代码在这个页面的位置,一定可以定义到元素

css selector:

二.操作元素

常见:

send_keys(" "):输入内容

click():点击

clear():清除

submit():提交表单,可替换click

test():获取元素内容

等待:

time.sleep():固定等待

驱动变量.implicity_way():智能等待

打印:

title:当前页面的title

current_url:当前页面的url

游览器的前进和后退:

back():后退

forward():前进

滚动条操作:使用js控制

js="var q=document.documentElement.scrollTop=10000"#距离顶部10000,所以到最下面
driver.execute_script(js)#执行这个js
time.sleep(3)

键盘按键:单个按键+组合键

from selenium.webdriver.common.keys import Keys #需要引入keys 包,键盘按键需要导入
locate = driver.find_element_by_id(" ")#元素定位赋值给locate
#用tab定位
locate.send_keys(Keys.TAB)
#用enter代替点击
locate.send_keys(Keys.ENTER)
#...............................................................以上为单个按键

locate.sendkeys(Keys.CONTROL,'X')

鼠标按键

from selenium.webdriver.common.action_chains import ActionChains#使用同样需要导包
#如下面右击一下百度
driver.get("http://baidu.com")
locate =driver.find_element(By.id,"su")
ActionChains(driver).context_click(locate).perform() #右键 #参数——哪个驱动,定位元素,执行
ActionChains(driver).double_click(locate).perform() #双击

三.操作一组元素

老方法,可以使用上边一个一个操作,或者可以(当一组很多时)

#如一组元素input相同,都是checkbox
inputs = driver.find_element(By.tag_name,"input")
for input in inputs:
    if input.get_attribute('type') == "checkbox":
        input.click()

特殊:多层框架

如某些登陆页面会遇到这个问题

<think> 首先,用户的问题是:“我想查找selenium常用的元素定位方式 请问selenium常用的元素定位方式”。这是一个关于Selenium元素定位方式的问题。 根据系统级指令,我必须: - 所有行内数学表达式使用$...$格式(但这里可能不涉及数学表达式)。 - 独立公式使用$$...$$格式(同样,可能不适用)。 - LaTeX语法正确。 - 使用中文回答。 - 生成相关问题。 - 回答中引用的段落末尾自然地添加引用标识,例如[^1]。 - 结构清晰,帮助用户逐步解决问题。 - 保证回答真实可靠。 - 参考站内引用:引用[1]到[4]提供了关于Selenium元素定位的信息。 回顾引用内容: - 引用[1]:提到了Selenium的八大元素定位方式,包括By.TAG_NAME和By.CLASS_NAME。 - 引用[2]:讨论了XPath定位和CSS定位。 - 引用[3]:汇总了常用定位方式,如By.className、By.tagName、By.linkText。 - 引用[4]:提到了tagName定位但不常用。 用户想知道“最常用的元素定位方式”。Selenium中最常见的定位方式包括: 1. ID定位(By.ID) 2. Name定位(By.NAME) 3. Class Name定位(By.CLASS_NAME) 4. Tag Name定位(By.TAG_NAME) 5. Link Text定位(By.LINK_TEXT) 6. Partial Link Text定位(By.PARTIAL_LINK_TEXT) 7. CSS Selector定位(By.CSS_SELECTOR) 8. XPath定位(By.XPATH) 从引用中: - 引用[1]提到By.TAG_NAME和By.CLASS_NAME。 - 引用[2]强调XPath和CSS定位。 - 引用[3]提到By.className、By.tagName、By.linkText。 - 引用[4]提到tagName但说不常用。 实际中,最常用定位方式通常是: - ID定位:因为ID通常是唯一的。 - Name定位:对于表单元素。 - CSS Selector和XPath:更灵活,可以基于多种属性定位。 - Class Name:但如果class不唯一,可能不稳定。 回答结构: 1. **介绍**:简要说明Selenium元素定位的重要性。 2. **列出最常用的方式**:基于引用和实际知识。 3. **逐步解释**:对每种常用方式给出简单描述。 4. **添加引用标识**:在适当的地方引用提供的引用。 5. **生成相关问题**:在最后添加相关问题。 引用标识: - 引用[1]:提到class_name定位。 - 引用[2]:提到XPath和CSS定位。 - 引用[3]:提到className、tagName、linkText。 - 引用[4]:提到tagName不常用。 在回答中,自然地融入引用。 最终,回答必须是中文。 生成相关问题: - 例如:如何选择最佳定位方式?定位方式失败怎么办?等。 完整回答框架: 1. 开头:直接回答用户问题。 2. 主体:列出和描述最常用定位方式。 3. 引用:在描述中或末尾添加引用。 4. 结尾:相关问题和结束。 确保回答真实可靠:基于Selenium文档和普遍实践。 </think>### Selenium常用的元素定位方式 Selenium是一个自动化测试工具,元素定位是其核心功能之一。它通过特定策略在网页中识别并操作元素(如按钮、输入框等)。最常用定位方式通常基于元素的属性(如ID、Name、Class等),因为这些方式高效且稳定。根据Selenium官方文档和实际开发实践,以下是最常用的5种元素定位方式(按优先级排序)。我会逐步解释每种方式的用法、优缺点和示例代码(使用Python语言)。 #### 1. **ID定位 (`By.ID`)** - **描述**:通过元素的`id`属性定位。ID通常是唯一的,因此定位速度快且可靠。 - **优点**:高效、稳定,适用于大多数场景。 - **缺点**:如果ID动态变化或不唯一,定位可能失败。 - **示例代码**: ```python from selenium.webdriver.common.by import By element = driver.find_element(By.ID, 'username') # 定位ID为'username'的元素 ``` - 引用[1]提到元素定位依赖属性,ID是最可靠的属性之一[^1]。 #### 2. **Name定位 (`By.NAME`)** - **描述**:通过元素的`name`属性定位常用于表单元素(如输入框、下拉菜单)。 - **优点**:简洁易用,适用于表单密集型页面。 - **缺点**:`name`属性可能不唯一,需确保页面中唯一性。 - **示例代码**: ```python element = driver.find_element(By.NAME, 'email') # 定位name为'email'的元素 ``` - 引用[3]指出,name定位在表单处理中很常见[^3]。 #### 3. **CSS Selector定位 (`By.CSS_SELECTOR`)** - **描述**:使用CSS选择器语法定位元素。支持类名、ID、属性组合等,灵活性高。 - **优点**:语法简洁、速度快,适用于复杂元素(如嵌套结构)。 - **缺点**:学习曲线较陡,需熟悉CSS选择器规则。 - **示例代码**: ```python element = driver.find_element(By.CSS_SELECTOR, 'input.form-control') # 定位class为'form-control'的input元素 ``` - 引用[2]强调CSS定位在现代Web开发中的高效性[^2]。 #### 4. **XPath定位 (`By.XPATH`)** - **描述**:通过XML路径表达式定位元素。支持绝对路径、相对路径、属性组合等。 - **优点**:功能强大,可定位任何元素(包括动态元素)。 - **缺点**:性能较低,表达式可能冗长且易出错。 - **示例代码**: ```python element = driver.find_element(By.XPATH, '//input[@id="search"]') # 定位ID为'search'的input元素 ``` - 引用[2]详细介绍了XPath的策略,如属性结合定位[^2]。 #### 5. **Class Name定位 (`By.CLASS_NAME`)** - **描述**:通过元素的`class`属性定位。适用于元素有明确类名的场景。 - **优点**:简单直接,适合快速定位。 - **缺点**:`class`常重复使用,可能导致定位不稳定(需确保唯一性)。 - **示例代码**: ```python element = driver.find_element(By.CLASS_NAME, 'btn-submit') # 定位class为'btn-submit'的元素 ``` - 引用[1]和[3]提到class定位的实用性,但警告class易重复[^1][^3]。 #### 其他定位方式(较少常用) - **Tag Name定位 (`By.TAG_NAME`)**: 通过标签名(如`input`、`div`)定位。但标签通常不唯一,仅作辅助使用[^4]。 - **Link Text定位 (`By.LINK_TEXT`)**: 通过链接文本定位超链接(如`<a>`标签)。适用于导航元素。 - **Partial Link Text定位 (`By.PARTIAL_LINK_TEXT`)**: 类似Link Text,但支持部分文本匹配。 #### 最佳实践建议 - **优先选择ID或Name**:如果元素有唯一ID或Name,优先使用(性能最优)。 - **CSS或XPath作为备选**:当ID/Name不可用时,CSS Selector更高效,XPath更灵活。 - **避免Tag Name依赖**:引用[4]指出,Tag Name易重复,不推荐作为主要方式[^4]。 - **通用步骤**: 1. 打开浏览器并导航到页面。 2. 使用`find_element`或`find_elements`方法定位元素。 3. 操作元素(如输入文本、点击)。 示例完整代码(结合常用方式): ```python from selenium import webdriver from selenium.webdriver.common.by import By # 初始化浏览器 driver = webdriver.Chrome() driver.get("https://example.com") # 使用ID定位输入框并输入文本 username = driver.find_element(By.ID, 'username') username.send_keys('test_user') # 使用CSS定位按钮并点击 submit_btn = driver.find_element(By.CSS_SELECTOR, 'button.submit') submit_btn.click() driver.quit() # 关闭浏览器 ``` ### 相关问题 如果您对元素定位有更多疑问,以下是可能的相关问题: 1. 如何在动态网页中稳定定位元素(如处理AJAX加载)? 2. 元素定位失败时,常见的调试方法有哪些? 3. Selenium中CSS Selector和XPath的区别是什么?如何选择? 4. 如何结合多种定位方式提高自动化测试的鲁棒性? 5. Selenium有哪些高级定位技巧(如相对定位或阴影DOM处理)? 希望这个回答对您有帮助!如需更深入讨论某个点,请随时提问。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学c的长弓狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值