【03】Selenium+Python 八种定位元素方法

操作元素,需要先查找定位到对应的元素。

查找单个元素:driver.find_element() 返回是一个web element 对象

查找多个元素:driver.find_elements() 返回是一个list对象

By 是 Selenium 中一个非常重要的类,用于定位网页元素。

使用需要导入By模块

python 复制代码
from selenium.webdriver.common.by import By  # 导入 By 模块

常用方法及示例

1. By.ID

根据元素的 ID 定位。

ID一般不会重复。

python 复制代码
element = driver.find_element(By.ID, "kw")

2.By.NAME

根据元素的 名称 定位。

python 复制代码
element = driver.find_element(By.NAME, "wd")

3.By.CLASS_NAME

根据元素的 类名 定位。

python 复制代码
element = driver.find_element(By.CLASS_NAME, "s_ipt")

4.By.TAG_NAME

根据元素的 标签名 定位。

一般与driver.find_elements()方法一起使用,因为一个页面中tag name非常容易重复。

python 复制代码
element = driver.find_elements(By.TAG_NAME,'input')
print(type(element))

find_elements 返回的是list 可以通过遍历list的方法获取每个元素

5.By.LINK_TEXT

根据元素的 链接文本 定位。

python 复制代码
element = driver.find_element(By.LINK_TEXT, "新闻")

6.By.PARTIAL_LINK_TEXT

根据元素的 部分链接文本 定位。

同样还是上面那个新闻链接。这样也能找到。

python 复制代码
element = driver.find_element(By.PARTIAL_LINK_TEXT, "新")

7.By.XPATH

根据元素的 XPath 定位。

在对应元素上,右键,copy,可复制xpath路径。

python 复制代码
    #复制的相对路径
    element = driver.find_element(By.XPATH, "//*[@id='kw']")
    #复制的绝对路径 很长不推荐使用
    element = driver.find_element(By.XPATH, "/html/body/div/div[2]/div[5]/div[1]/div/form/span[1]/input")
    #自己手写路径匹配规则
    element = driver.find_element(By.XPATH, "//input[@id='kw' and @name='wd' ]")

8.By.CSS_SELECTOR

根据元素的 CSS选择器 定位。

这个同样也可以在对应元素上,右键,copy,复制CSS选择器。

python 复制代码
# 复制的selector
driver.find_element(By.CSS_SELECTOR,"#kw")
#自己手写
element = driver.find_element(By.CSS_SELECTOR, "input[name='wd']")
相关推荐
乐观勇敢坚强的老彭10 分钟前
2026全国青少年信息素养大赛考纲
python·数学建模
YMWM_1 小时前
【问题】thor上的cubLas
linux·python·thor
wefly20171 小时前
免安装!m3u8live.cn在线 M3U8 播放器,小白也能快速上手
java·开发语言·python·json·php·m3u8·m3u8在线转换
2401_873544921 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
程序员小远1 小时前
软件测试常见Bug清单
自动化测试·软件测试·python·功能测试·测试工具·测试用例·bug
小仙女的小稀罕2 小时前
听不清重要会议录音急疯?这款常见AI工具听脑AI精准转译
开发语言·人工智能·python
书到用时方恨少!2 小时前
Python random 模块使用指南:从入门到精通
开发语言·python
第一程序员2 小时前
Python 4.0正式发布:新特性与学习建议
python·github
IAUTOMOBILE3 小时前
用Python批量处理Excel和CSV文件
jvm·数据库·python