selenium元素定位

find_element和find_elements

元素定位有两个表达式,分别为find_element()和find_elements(),它们的不同点如下:

find_element():找出的为单个元素,若有多个元素为同一表达式,则默认定位第一个元素,可以直接进行点击,输入等操作。

find_elements():找出的为一组列表,不能直接对元素进行点击等操作,需要加索引,取列表的第n个元素。

Xpath定位

Xpath定位方法是基本的一类定位方法,XPath(XML Path Language)是一种用于定位XML和HTML文档中元素的语言。其在自动化脚本中使用的例子如下:

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Chrome()

browser.get("https://www.baidu.com")

通过xpath定位输入框,输入内容selenium

browser.find_element(By.XPATH, '//input[@id="kw"]').send_keys('selenium')

停留五秒后关闭浏览器

time.sleep(5)

browser.quit()

这个XPath表达式将会匹配id为kw的input元素。

css定位

CSS选择器是一种强大且常用的定位方式。它能够通过元素的属性、标签名、类名等准确地定位到页面元素。其在自动化脚本中使用的例子如下:

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Chrome()

browser.get("https://www.baidu.com")

通过css定位输入框,输入内容selenium

browser.find_element(By.CSS_SELECTOR, '.s_ipt').send_keys('selenium')

停留五秒后关闭浏览器

time.sleep(5)

browser.quit()

id定位

根据元素的id属性值定位,最为方便且唯一,但是现在很多元素的id都是动态生成的,在使用id属性定位时需要注意。其在自动化脚本中使用的例子如下:

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Chrome()

browser.get("https://www.baidu.com")

通过ID定位输入框,输入内容selenium

browser.find_element(By.ID, 'kw').send_keys('selenium')

停留五秒后关闭浏览器

time.sleep(5)

browser.quit()

name定位

根据元素的name属性值定位,但是我们需要注意,定位到的元素可能并不是唯一的。其在自动化脚本中使用的例子如下:

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Chrome()

browser.get("https://www.baidu.com/")

通过name属性选择文本框元素,并设置内容

browser.find_element(By.NAME,'wd').send_keys("selenium")

通过通过ID属性获取"百度一下"按钮,并执行点击操作

browser.find_element(By.ID,"su").click()

停留五秒后关闭浏览器

time.sleep(5)

browser.quit()

class定位

class定位,根据元素的class属性值定位,但可能受JS影响动态变化。定位到的标签不一定是唯一的。其在自动化脚本中使用的例子如下:

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Chrome()

browser.get("https://www.baidu.com/")

time.sleep(2)

通过class属性选择元素

browser.find_element(By.CLASS_NAME,'s_ipt').send_keys("selenium")

time.sleep(2)

browser.find_element(By.ID,"su").click()

停留三秒后关闭浏览器

time.sleep(3)

browser.quit()

tag定位

tag name定位,根据元素的标签名定位,定位到的标签不一定是唯一的。其在自动化脚本中使用的例子如下:

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Firefox()

browser.get("https://www.baidu.com")

time.sleep(2)

选择<button></button>标签(搜索按钮),执行点击操作

browser.find_element(By.TAG_NAME, "button").click()

停留三秒后关闭浏览器

time.sleep(3)

browser.quit()

link定位

link表示包含有属性href的标签元素,如:<a href="https://www.csdn.net">linktext</a>可以通过LINK_TEXT进行定位。

find_element(By.LINK_TEXT,'XX')根据链接文本全匹配进行精确定位。

find_element(By.PARTIAL_LINK_TEXT,'XX')根据链接文本模糊匹配进行定位。

By.LINK_TEXT精确定位

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Chrome()

browser.get("https://www.baidu.com")

选择https://news.baidu.com/标签,执行点击操作

browser.find_element(By.LINK_TEXT, "新闻").click()

停留三秒后关闭浏览器

time.sleep(3)

browser.quit()

import time

导入selenium包

from selenium import webdriver

from selenium.webdriver.common.by import By

启动并打开指定页面

browser = webdriver.Chrome()

browser.get("https://www.baidu.com")

选择https://news.baidu.com/标签,执行点击操作

browser.find_element(By.PARTIAL_LINK_TEXT, "新").click()

停留三秒后关闭浏览器

time.sleep(3)

browser.quit()

相关推荐
安冬的码畜日常8 小时前
【JUnit实战3_28】第十七章:用 JUnit 5 实测 SpringBoot 项目
spring boot·功能测试·测试工具·设计模式·单元测试·junit5
程序员三藏11 小时前
接口自动化测试框架搭建详解
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·接口测试
卖个几把萌14 小时前
【02】JMeter登录保存cookie用于后面的接口
测试工具·jmeter
测试老哥14 小时前
Jmeter吞吐量控制器详解
自动化测试·软件测试·python·测试工具·jmeter·测试用例·压力测试
吗喽1号14 小时前
python-xmind转Excel
python·测试工具
卓码软件测评1 天前
第三方软件测试机构:【“Bug预防”比“Bug发现”更有价值:如何建立缺陷根因分析与流转机制?】
功能测试·测试工具·单元测试·测试用例·压力测试·可用性测试
测试老哥1 天前
python+requests+excel 接口测试
自动化测试·软件测试·python·测试工具·测试用例·excel·接口测试
Run Freely9371 天前
web自动化测试_selenium_05_窗口截图、验证码处理
selenium·测试工具
Run Freely9371 天前
web自动化测试-Selenium04_iframe切换、窗口切换
selenium
B站计算机毕业设计之家1 天前
Python招聘数据分析可视化系统 Boss直聘数据 selenium爬虫 Flask框架 数据清洗(附源码)✅
爬虫·python·selenium·机器学习·数据分析·flask