【selenium】定位页面元素
【摘要】
文章目录
一、已被废弃的用法1、根据id定位2、根据class定位3、根据name定位4、根据tag定位5、根据xpath定位6、根据css定位7、根据link定位8、根据partial_link...
一、已被废弃的用法
1、根据id定位
- 定义一个元素
find_element_by_id()
- 1
- 定义多个元素
find_elements_by_id()
- 1
2、根据class定位
- 定义一个元素
find_element_by_class_name()
- 1
- 定义多个元素
find_elements_by_class_name()
- 1
3、根据name定位
- 定义一个元素
find_element_by_name()
- 1
- 定义多个元素
find_elements_by_name()
- 1
4、根据tag定位
- 定义一个元素
find_element_by_tag_name()
- 1
- 定义多个元素
find_elements_by_tag_name()
- 1
5、根据xpath定位
- 定义一个元素
find_element(By.XPATH, ' ')
- 1
- 定义多个元素
find_elements_by_xpath()
- 1
6、根据css定位
- CSS选择器参考手册链接:
https://www.w3school.com.cn/cssref/css_selectors.asp
- 定义一个元素
find_element_by_css_selector()
- 1
- 定义多个元素
find_elements_by_css_selector()
- 1
7、根据link定位
定义文本链接
- 定义一个元素
find_element_by_link_text()
- 1
- 定义多个元素
find_elements_by_link_text()
- 1
8、根据partial_link定位
定义部分文本链接
- 定义一个元素
find_element_by_partial_link_text()
- 1
- 定义多个元素
find_elements_by_partial_link_text()
- 1
二、现在的写法
需要先导入:
from selenium.webdriver.common.by import By
- 1
将之前的 find_element_by_*
命令改用 find_element()
命令
如:
text_label = driver.find_element_by_xpath('//*[@id="kw"]')
- 1
改为:
text_label = driver.find_element(By.XPATH, '//*[@id="kw"]')
- 1
三、实例
结合上一节,进行实例演示,以百度为例:
首先,先手动查看一下搜索框信息和搜索按钮
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
driver = webdriver.Chrome()
# 访问百度
driver.get('https://baidu.com')
# 等待3秒
time.sleep(3)
# 定位到搜索框
text_label = driver.find_element(By.XPATH, '//*[@id="kw"]')
# 在搜索框中输入 CSDN
text_label.send_keys('CSDN')
# 等待3秒
time.sleep(3)
# 清楚搜索框内容
text_label.clear()
# 等待3秒
time.sleep(3)
# 定位到“百度一下”按钮
button = driver.find_element(By.XPATH, '//*[@id="su"]')
# 输出按钮元素是否可见
print(button.is_displayed())
# 输出按钮的大小
print(button.size)
# 关闭所有页面
driver.quit()
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
文章来源: luckystar.blog.csdn.net,作者:爱打瞌睡的CV君,版权归原作者所有,如需转载,请联系作者。
原文链接:luckystar.blog.csdn.net/article/details/123161175
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)