2、selenium.元素定位(find_element_by)

本文介绍了Selenium中八种定位网页元素的方法,包括通过id、name、tag_name、class_name、css、xpath、link_text及partial_link_text。同时,以百度搜索为例,展示了如何在Python测试用例中应用这些定位方式,包括窗口句柄的使用和测试用例的执行流程。请注意在实际运行代码时可能需要根据具体情况进行调整。

一、八种定位元素的方式

1、通过id定位元素:find_element_by_id(“id_vaule”)
2、通过name定位元素:find_element_by_name(“name_vaule”)
3、通过tag_name定位元素:find_element_by_tag_name(“tag_name_vaule”)
4、通过class_name定位元素:find_element_by_class_name(“class_name”)
5、通过css定位元素:find_element_by_css_selector()
6、通过xpath定位元素:find_element_by_xpath(“xpath”)
7、通过link:find_element_by_link_text(“text_vaule”)
8、通过find_element_by_partial_link_text()

二、以下是以“百度”为例,书写的一段简单的测试用例


1、新建 base.py

‘’’
1、先获取当前的窗口句柄:driver.current_window_handle
2、在获取所有的窗口句柄:driver.window_handles
3、判断是否是想要操作的窗口:
如果是,就可以对窗口进行操作
如果不是,跳转到另外一个窗口,对另外一个窗口进行操作:driver.switch_to_window
‘’’
在这里插入图片描述


2、新建 test_window.py

在Python中使用Selenium库进行网页自动化测试时,`find_element_by_xpath` 方法用于通过XPath定位元素。XPath是一种在XML文档中查找信息的语言,它也可以用于HTML文档。 以下是如何使用 `find_element_by_xpath` 方法的简单介绍: 1. **导入必要的库**: 首先,你需要导入Selenium库并启动一个浏览器实例。 ```python from selenium import webdriver ``` 2. **启动浏览器**: 创建一个浏览器实例,例如Chrome或Firefox。 ```python driver = webdriver.Chrome() # 或者使用webdriver.Firefox() ``` 3. **打开网页**: 使用 `get` 方法打开你想要操作的网页。 ```python driver.get("http://example.com") ``` 4. **使用XPath定位元素**: 使用 `find_element_by_xpath` 方法来定位页面上的元素。你需要提供一个有效的XPath表达式。 ```python element = driver.find_element_by_xpath('//input[@name="q"]') ``` 5. **对元素进行操作**: 一旦你找到了元素,你可以对它进行各种操作,比如点击、输入文本等。 ```python element.send_keys("Hello, World!") ``` 6. **关闭浏览器**: 完成操作后,记得关闭浏览器。 ```python driver.quit() ``` ### 示例代码 下面是一个完整的示例代码,展示了如何使用 `find_element_by_xpath` 方法: ```python from selenium import webdriver from selenium.webdriver.common.keys import Keys import time # 启动Chrome浏览器 driver = webdriver.Chrome() try: # 打开Google主页 driver.get("http://www.google.com") # 等待页面加载 time.sleep(2) # 使用XPath定位搜索框元素 search_box = driver.find_element_by_xpath('//input[@name="q"]') # 在搜索框中输入文本 search_box.send_keys("Python Selenium") # 模拟按下回车键 search_box.send_keys(Keys.RETURN) # 等待搜索结果加载 time.sleep(2) finally: # 关闭浏览器 driver.quit() ``` ### 注意事项 - XPath表达式需要根据实际网页的结构进行调整。如果XPath不正确,可能会抛出 `NoSuchElementException` 异常。 - 为了提高稳定性,可以使用显式等待(Explicit Wait)而不是简单的 `time.sleep`,这样可以确保元素已经加载完毕再进行操作。 希望这些信息对你有所帮助!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大城市的小人物

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

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

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

打赏作者

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

抵扣说明:

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

余额充值