selenium---元素定位(find_element)

本文介绍了Selenium库中的find_element方法,用于在网页中定位元素。通过导入selenium.webdriver.common.by模块,利用By.ID、By.XPATH和By.CSS_SELECTOR等定位方式找到特定元素,例如在百度搜索中输入关键词并点击搜索。示例代码展示了如何打开百度,输入搜索词并执行搜索,最后关闭浏览器。此外,还提及了time.sleep()函数用于延长浏览器的运行时间。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

find_element属于定位元素的一种方法,包含了常用的定位方法。
在使用find——element 时 一定要导入相关的包,不然会报错

from selenium import webdriver
# 一定要导入这个包
from selenium.webdriver.common.by import By

源码如下

 def find_element(self, by=By.ID, value=None) -> WebElement:
        """
        Find an element given a By strategy and locator.

        :Usage:
            ::

                element = driver.find_element(By.ID, 'foo')

        :rtype: WebElement
        """
        if isinstance(by, RelativeBy):
            elements = self.find_elements(by=by, value=value)
            if not elements:
                raise NoSuchElementException(f"Cannot locate relative element with: {by.root}")
            return elements[0]

        if by == By.ID:
            by = By.CSS_SELECTOR
            value = '[id="%s"]' % value
        elif by == By.CLASS_NAME:
            by = By.CSS_SELECTOR
            value = ".%s" % value
        elif by == By.NAME:
            by = By.CSS_SELECTOR
            value = '[name="%s"]' % value

        return self.execute(Command.FIND_ELEMENT, {
            'using': by,
            'value': value})['value']

定位

在这里插入图片描述
以百度页面为例:
选中搜索框,右键点击检查
在这里插入图片描述
本篇一切方法都是基于此。

代码

1.选择要使用的浏览器和搜索网站,以Chrome浏览器和百度为例

driver = webdriver.Chrome()
driver.get("http://www.baidu.com/")

2.以 id 为例
从上面的图可以看到,id 为 “kw”

#搜索框 id 为 kw,向搜索框发送“脱口秀大会进行搜索”
driver.find_element(By.ID, 'kw').send_keys('脱口秀大会')
#百度一下的 id 为 su,然后点击进行搜索
driver.find_element(By.ID, 'su').click()
#关闭浏览器
driver.close()

然后运行浏览器就可以进行搜索了 ,使用完一定要使用driver.close()进行关闭
如果想要界面待得时间长一点,还可以导入包

#包
import time

#8秒后关闭浏览器
time.sleep(8)
driver.close()

3.除了id外,下面这些都可以用来进行查找,用来查找的一定要是唯一的,如果不唯一就会报错,浏览器也会停止在网页首页,不进行查找,id具有唯一性

在这里插入图片描述
4.用XPATH 和 CSS_SELECTOR查找的本质都是 id查找,所以也是唯一的
在上面查找的基础上,点击所要查找的id行,右键复制里

在这里插入图片描述
使用同上

#  driver.find_element(By.XPATH,'//*[@id="kw"]').send_keys("创造101")
#  driver.find_element(By.XPATH, '//*[@id="su"]').click()

driver.find_element(By.CSS_SELECTOR, '#kw').send_keys("qq")
driver.find_element(By.CSS_SELECTOR, '#su').click()
XPath是一种XML文档的定位方法,也可以用于HTML文档的定位Selenium中也可以使用XPath来定位网页元素。下面是使用XPath定位元素的详细步骤: 1. 打开浏览器并访问网页: ```python from selenium import webdriver driver = webdriver.Chrome() driver.get("http://www.example.com") ``` 2. 使用XPath定位元素: ```python # 通过元素id定位 element = driver.find_element_by_xpath('//*[@id="element_id"]') # 通过元素name定位 element = driver.find_element_by_xpath('//*[@name="element_name"]') # 通过元素class定位 element = driver.find_element_by_xpath('//*[@class="element_class"]') # 通过元素标签名定位 element = driver.find_element_by_xpath('//tag_name') # 通过元素属性定位 element = driver.find_element_by_xpath('//*[@attribute_name="attribute_value"]') # 通过元素文本内容定位 element = driver.find_element_by_xpath('//*[text()="text_content"]') # 通过元素部分文本内容定位 element = driver.find_element_by_xpath('//*[contains(text(), "text_content")]') ``` 3. 对元素进行操作: ```python # 输入文本 element.send_keys("text_input") # 点击元素 element.click() # 获取元素文本 print(element.text) # 获取元素属性值 print(element.get_attribute("attribute_name")) ``` 注意事项: - XPath定位需要用到浏览器的开发者工具,在开发者工具中可以查看元素的XPath路径。 - XPath路径中的引号需要用不同类型的引号包裹,例如在单引号内使用双引号包裹。 - 如果XPath路径中包含斜杠(/),则需要使用双斜杠(//)或者使用单引号包裹整个XPath路径。 - 在XPath路径中没有找到元素时,会抛出NoSuchElementException异常。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值