掌握Selenium4:详解各种定位方式

Selenium4中有多种元素定位方式,主要包括以下几种:

  1. 通过ID属性定位:根据元素的id属性进行定位。
  2. 通过name属性定位:当元素没有id属性而有name属性时,可以使用name属性进行元素定位。
  3. 通过class name定位:可以根据元素的class属性进行定位。
  4. 通过tag name定位:根据HTML标签名进行定位。
  5. 通过link text定位:根据链接的文本内容进行定位。
  6. 通过partial link text定位:根据链接的部分文本内容进行定位。
  7. 通过css selector定位:根据CSS选择器规则进行定位。
  8. 通过xpath定位:根据XPath表达式进行定位。

分别对应by方法的:

python 复制代码
class By:
    """Set of supported locator strategies."""

    ID = "id"
    XPATH = "xpath"
    LINK_TEXT = "link text"
    PARTIAL_LINK_TEXT = "partial link text"
    NAME = "name"
    TAG_NAME = "tag name"
    CLASS_NAME = "class name"
    CSS_SELECTOR = "css selector"

示例:

python 复制代码
from selenium import webdriver
from selenium.webdriver.common.by import By
from time import sleep


class TestCase(object):
    def __init__(self):
        # 初始化方法,创建一个Chrome浏览器实例并打开百度首页。
        self.driver = webdriver.Chrome()
        self.driver.get("https://www.baidu.com/")
        self.driver.maximize_window()  # 窗口最大化
        sleep(1)

    def test_id(self):
        '''
        通过ID定位搜索框,输入"selenium"并点击搜索按钮。
        :return:
        '''
        element = self.driver.find_element(by=By.ID, value="kw")
        element.send_keys("selenium")
        print(type(element))
        self.driver.find_element(by=By.ID, value="su").click()
        sleep(3)
        # self.driver.quit()

    def test_name(self):
        '''
        通过NAME定位搜索框,输入"selenium"并点击搜索按钮。
        :return:
        '''
        element = self.driver.find_element(by=By.NAME, value="wd")
        element.send_keys("selenium")
        print(type(element))
        self.driver.find_element(by=By.ID, value="su").click()
        sleep(3)
        self.driver.quit()

    def test_link_text(self):
        '''
        通过链接文本定位百度首页并点击。
        :return:
        '''
        self.test_id()
        self.driver.find_element(By.LINK_TEXT, value="百度首页").click()
        sleep(3)
        self.driver.quit()

    def test_partiallink_text(self):
        '''
        通过部分链接文本定位百度首页并点击。
        :return:
        '''
        self.test_id()
        self.driver.find_element(By.PARTIAL_LINK_TEXT, value="首页").click()
        sleep(3)
        self.driver.quit()

    def test_xpath(self):
        '''
         通过XPath定位搜索框,输入"selenium"并点击搜索按钮。
        :return:
        '''
        element = self.driver.find_element(by=By.XPATH, value='//*[@id="kw"]')
        element.send_keys("selenium")
        print(type(element))
        self.driver.find_element(by=By.XPATH, value='//*[@id="su"]').click()
        sleep(3)
        self.driver.quit()

    def test_tag(self):
        '''
        通过标签名定位input元素。
        :return:
        '''
        element = self.driver.find_element(by=By.TAG_NAME, value='input')
        print(element)

    def test_css_selector(self):
        '''
        通过CSS选择器定位搜索框,输入"selenium"并点击搜索按钮。
        :return:
        '''
        element = self.driver.find_element(by=By.CSS_SELECTOR, value='#kw')
        element.send_keys("selenium")
        print(type(element))
        self.driver.find_element(by=By.XPATH, value='//*[@id="su"]').click()
        sleep(3)
        self.driver.quit()

    def test_class_name(self):
        '''
        通过类名定位搜索框,输入"selenium"并点击搜索按钮。
        :return: 
        '''
        element = self.driver.find_element(by=By.CLASS_NAME, value='s_ipt')
        element.send_keys("selenium")
        print(type(element))
        self.driver.find_element(by=By.XPATH, value='//*[@id="su"]').click()
        sleep(3)
        self.driver.quit()


if __name__ == '__main__':
    case = TestCase()
    # case.test_id()
    # case.test_name()
    # case.test_link_text()
    # case.test_partiallink_text()
    # case.test_xpath()
    # case.test_tag()
    # case.test_css_selector()
    case.test_class_name()

工具类封装及使用:

python 复制代码
from time import sleep

from selenium import webdriver
from selenium.webdriver.common.by import By

def get_element(driver,*loc):
# 使用find_element方法查找元素,传入定位方式和定位值
    e = driver.find_element(*loc)
# 返回找到的元素
    return e

if __name__ == '__main__':
    driver = webdriver.Chrome()
    driver.get("https://www.baidu.com/")
    driver.maximize_window()
    loc = (By.ID, "kw")
    get_element(driver,*loc).send_keys("selenium")
    sleep(10)
相关推荐
鸡鸭扣29 分钟前
Docker:3、在VSCode上安装并运行python程序或JavaScript程序
运维·vscode·python·docker·容器·js
paterWang1 小时前
基于 Python 和 OpenCV 的酒店客房入侵检测系统设计与实现
开发语言·python·opencv
东方佑1 小时前
使用Python和OpenCV实现图像像素压缩与解压
开发语言·python·opencv
神秘_博士2 小时前
自制AirTag,支持安卓/鸿蒙/PC/Home Assistant,无需拥有iPhone
arm开发·python·物联网·flutter·docker·gitee
Moutai码农3 小时前
机器学习-生命周期
人工智能·python·机器学习·数据挖掘
小白教程4 小时前
python学习笔记,python处理 Excel、Word、PPT 以及邮件自动化办公
python·python学习·python安装
武陵悭臾4 小时前
网络爬虫学习:借助DeepSeek完善爬虫软件,实现模拟鼠标右键点击,将链接另存为本地文件
python·selenium·网络爬虫·pyautogui·deepseek·鼠标右键模拟·保存链接为htm
代码猪猪傻瓜coding5 小时前
关于 形状信息提取的说明
人工智能·python·深度学习
码界筑梦坊6 小时前
基于Flask的第七次人口普查数据分析系统的设计与实现
后端·python·信息可视化·flask·毕业设计
微笑的Java6 小时前
Python - 爬虫利器 - BeautifulSoup4常用 API
开发语言·爬虫·python