当前位置: 首页 > news >正文

Python的web自动化学习(五)Selenium的隐式等待(元素定位)

引言:
WebDriver隐式等待是一种全局性的等待方式,它会在查找元素时设置一个固定的等待时间。当使用隐式等待时,WebDriver会在查找元素时等待一段时间,如果在等待时间内找到了元素,则立即执行下一步操作;如果超过等待时间仍未找到元素,则抛出NoSuchElementException异常。

其元素定位8种方法

在这里插入图片描述

1.通过id或name定位

<input type="text" class="s_ipt" name="wd" id="kw" maxlength="100" autocomplete="off">#通过元素所带的id和name属性对元素定位:
brower.find_element_by_id("kw")
brower.find_element_by_name("wd")

2.通过class name或tag name定位

<div class="jstEditor">
<textarea cols="60" rows="10" accesskey="e" class="wiki-edit" name="issue[description]" id="issue_description">
</textarea>
</div>通过元素中带的class属性定位
brower.find_element_by_class_name("iki-edit")通过元素中的tag标签定位,这种定位方式极不靠谱,不推荐采取此种方式。
brower.find_element_by_tag_name("div")附加说明,如果class属性含有空格,那么取其中一个不重复的字段就可以了,例子:
<a title="新建版本" tabindex="200" class="icon-only icon-add" data-remote="true" data-method="get" href="/projects/bk_community/versions/new">新建版本</a>其中class的属性值为“icon-only icon-add”,取其中“icon-only”、“ icon-add”都可以,但最好是取其中唯一的。
brower.find_element_by_class_name("icon-add")

3.通过link text和partial link text定位

<a href="http://news.baidu.com" target="_blank" class="mnav">新闻</a>
通过text link定位元素
brower.find_element_by_link_text("新闻")通过partial link text定位元素,当文字链接很长时,可以通过此方式取其中一部分,只要取的部分可以作为唯一标识。brower.find_element_by_partial_link_text("新")

4.xpath定位

此种定位方式需知晓xpath路径,通过火狐浏览器就可以知道,具体如何操作,可参考我的另一篇博文https://blog.csdn.net/qq_30990097/article/details/81325681调用的方法为:brower.find_element_by_xpath("/html/body/div[1]/div/div[2]/ul/li[2]")
也可以通过相对路径自行填写,例如://*[@id="su"]/form/span/input              #通过上三级目录的id属性定位当然也可以通过某一级的name属性定位。

5.CSS定位

css定位有点麻烦,方法很多。以百度输入框html代码为例:<input type="text" class="s_ipt" name="wd" id="kw" maxlength="100" autocomplete="off">
定义浏览器
from selenium import webdriver
browser = webdriver.Chrome()
browser.get("https://www.baidu.com/")

6.通过id或class属性定位,方法见代码注释

#css通过id属性定位,用#号表示id属性browser.find_element_by_css_selector("#kw").send_keys("css通过id属性定位")#css通过class属性定位,用.表示class属性browser.find_element_by_css_selector(".s_ipt").clear()

7.通过标签定位

#css通过标签属性定位,无任何标识符,最好加上一个固定属性,否则会出错browser.find_element_by_css_selector("input[class=s_ipt]").send_keys("css通过标签属性定位")browser.find_element_by_css_selector("input#kw").send_keys("css通过标签属性定位")通过其他属性定位#css通过其他属性定位browser.find_element_by_css_selector("[name='wd']").send_keys("css通过name属性定位")browser.find_element_by_css_selector("[autocomplete='off']").clear()通过css层级关系定位还是以百度的输入框html代码为示例:定位代码:#css层级关系browser.find_element_by_css_selector("form#form>span>input").send_keys("通过层级定位")browser.find_element_by_css_selector("form.fm>span>input").clear()

8. 通过css索引定位

示例html代码:定位代码:#通过css索引定位browser.find_element_by_css_selector("select.pagination-page-list>option:nth-child(1)").click()
http://www.lryc.cn/news/216249.html

相关文章:

  • 20231102从头开始配置cv180zb的编译环境(欢迎入坑,肯定还有很多问题等着你)
  • CentOS 安装HTTP代理服务器 Squid
  • ubuntu下开发提效的小tips
  • Java反射详解:入门+使用+原理+应用场景
  • PostgreSQL 工具的相关介绍
  • 结合组件库实现table组件树状数据的增删改
  • Microsoft 365 管理自动化
  • unraid 安装并设置 zerotier 内网穿透安装 unraid 局域网内其他设备
  • 如何调试 Dubbo 协议调用过程
  • C++初阶 类和对象(上)
  • SoftwareTest4 - 咋设计一个好的测试用例
  • 自定义 Spring Boot Starter 组件
  • 功率放大器的种类和作用是什么
  • 分析外贸SEO推广流程?网站谷歌SEO优化方法?
  • 前端工程化需要知道的一些知识
  • 默认路由配置
  • Annotorious入门教程:图片注释工具
  • 一台服务器是否能够安装多个SSL证书?
  • 如何使用UDP打洞进行内网穿透
  • 如何滴水不漏的学完C语言?
  • 数据库深入浅出,数据库介绍,SQL介绍,DDL、DML、DQL、TCL介绍
  • 拓世大模型 | 立足行业所需,发力终端,缔造智能无限可能
  • NEFU数字图像处理(3)图像分割
  • 图论问题建模和floodfill算法
  • MySQL - 库的操作
  • 多次kerberos认证服务超时
  • Vuex源码-各原理简单总结
  • vcpkg 使用 cmake 编译C/C++工程代码时指定使用静态库链接编译
  • FlinkCDC系列:数据同步对部分字段的处理,只更新部分字段
  • Linux 包操作 (rpm)