-*- coding;utf-8 -*-
from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
#有八种元素定位方法:
#id, name, class name, tag name, link text,部分link text, xpath, css选择器 其中,find_elements_by_xxx 获取的是一组元素

前7种:

 <span id="s_kw_wrap" class="s_ipt_wr"><span class="soutu-btn"></span>
<span class="soutu-btn"></span>
<input type="text" class="s_ipt" name="wd" id="kw" maxlength="" autocomplete="off" value="">
<input></input>
</span>
<div id="u_sp" class="s-isindex-wrap s-sp-menu">
<a href="http://news.baidu.com" target="_blank" class="mnav">超长的新闻名称</a>
</div> #id
dr.find_element_by_id("kw")
#name
dr.find_element_by_name("wd")
#class name
dr.find_element_by_class_name("s_ipt")
#tag name (标签名称)
dr.find_element_by_tag_name("input") #适用于只有一个input标签
dr.find_elements_by_tag_name("input")[0].send_keys() #适用于多个input标签
dr.find_element_by_tag_name("//span/input[0]") #通过父级元素 #text link, 部分text link
dr.find_elements_by_link_text("超长的新闻名称")
dr.find_element_by_partial_link_text("新闻") #xpath
dr.find_element_by_xpath("//input[@id='kw']") # 双斜杠表示不确定
dr.find_element_by_xpath("/*[@id='kw']") # "*"表示所有元素
dr.find_element_by_xpath("//input[@name='wd']")
dr.find_element_by_xpath("//input[@class='s_ipt']")
dr.find_element_by_xpath("//input[@value='123']") dr.find_element_by_xpath("//span/input[0]")#通过父级
dr.find_element_by_xpath("//span[@class='bg s_ipt_wr']/input[0]")#通过父级 也可用多种属性集合
dr.find_element_by_xpath("//input[@id='kw' and @name='wd']")

CSS选择器:

 <span id="s_kw_wrap" class="s_ipt_wr"><span class="soutu-btn"></span>
<span class="soutu-btn"></span>
<input type="text" class="s_ipt" name="wd" id="kw" maxlength="" autocomplete="off" value="">
</span> #class 用“.”
dr.find_element_by_css_selector(".s_ipt") #id 用“#”
dr.find_element_by_css_selector("#kw") #name
dr.find_element_by_css_selector("[name=wd]")
dr.find_element_by_css_selector("name='wd'")
dr.find_element_by_css_selector("//input[name='wd']") #组合
dr.find_element_by_css_selector("span>input.s_ipt") #通过父级
dr.find_element_by_css_selector("span>input#kw")
dr.find_element_by_css_selector("span.s_ipt_wr>input")

selenium中,8种 find element 方法的更多相关文章

  1. Selenium中三种等待的使用方式---规避网络延迟、代码不稳定问题

    在UI自动化测试中,必然会遇到环境不稳定,网络慢的情况,这时如果你不做任何处理的话,代码会由于没有找到元素,而报错.这时我们就要用到wait(等待),而在Selenium中,我们可以用到一共三种等待, ...

  2. Sql Server中三种字符串合并方法的性能比较

    文章来自:博客园-DotNet菜园 最近正在处理一个合并字符吕的存储过程,在一个测试系统的开发中,要使用到字符串合并功能,直接在Sql中做.示例:有表內容﹕名称  內容1     abc1      ...

  3. ASP.NET中26种性能优化方法

    系统类  Type类,Object类,String类, Arrary类,Console类, Exception类,GC类, MarshalByRefObject类, Math类. DateTime结构 ...

  4. UI自动化时,解决selenium中无法点击Element:ElementClickInterceptedException

    在跑自动化时,页面上有2个下拉框,两个下拉框无论屏蔽哪一段都会成功,但是同时放开跑时会报错,百度给的解释是上面的下拉框元素覆盖了下面下拉框的元素定位,才会导致报错 百度的解决办法有2种: elemen ...

  5. Selenium:八种元素定位方法

    前言: 我们在做WEB自动化时,最根本的就是操作页面上的元素,首先我们要能找到这些元素,然后才能操作这些元素.工具或代码无法像我们测试人员一样用肉眼来分辨页面上的元素.那么我们怎么来定位他们呢? 在学 ...

  6. Python中两种处理错误方法的比较

    我所说的处理错误的方法,其实是try:,except和raise这两种. 首先抛出一个实例, dictt={'a':1,'b':2,'c':3} try: if dictt['d']>1: #字 ...

  7. UWP开发中两种网络图片缓存方法

    通常情况下,我们的程序需要从服务器读取图片,但如果需要不止一次读取某一张图片的话,就需要做本地缓存了,这样既为用户省一点流量,又能显得你的APP很快. 假如你已经知道了某一张图片的地址,那么第一件事就 ...

  8. iOS——浅谈iOS中三种生成随机数方法

    ios 有如下三种随机数方法:

  9. Keil C51程序设计中几种精确延时方法

    1 使用定时器/计数器实现精确延时 单片机系统一般常选用11.059 2 MHz.12 MHz或6 MHz晶振.第一种更容易产生各种标准的波特率,后两种的一个机器周期分别为1 μs和2 μs,便于精确 ...

随机推荐

  1. Tomcat、Weblogic、WebSphere、JBoss服务器的选择

    一.应用点 Tomcat是Apache基金会提供的Servlet容器,它支持JSP, Servlet和JDBC等J2EE关键技术,所以用户可以用Tomcat开发基于数据库,Servlet和JSP页面的 ...

  2. js学习总结:DOM节点二(dom基本操作)

    一.DOM继承树 DOM——Document Object Model DOM定义了表示修改文档所需要的方法.DOM对象即为宿主对象,由浏览器厂商定义,用来操作html和xml的一类厂商定义,也有人称 ...

  3. python 调用 java代码

    一.JPype简述 1.JPype是什么? JPype是一个能够让 python 代码方便地调用 Java 代码的工具,从而克服了 python 在某些领域(如服务器端编程)中的不足. 2.JPype ...

  4. 常见排序算法之python实现

    冒泡排序 简介 冒泡排序(英语:Bubble Sort)是一种简单的排序算法.它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.遍历数列的工作是重复地进行直到没有再需要交 ...

  5. docker 系列 - Java程序制作Docker Image推荐方案(转载)

    本文转自 https://segmentfault.com/a/1190000016449865  , 感谢作者! 本文的源代码在:https://github.com/chanjarste... 这 ...

  6. Delegate与Event关系

    1.Delegate是类型,Event是成员(本质为成员方法),Event成员类型派生于Delegate.仅此! 2.大概就好比说委托是C++里一个方法的模板,而event是这个模板具体的实现

  7. C# 绘图时使用抗锯齿会多出一个像素

    如下图,使用局部绘图覆盖后的效果. 减去像素后效果

  8. ms sql 导出单个表数据

    然后都是下一步操作

  9. char,wchar_t 长度

    (测试环境:VC++6.0) char类型 wchar_t类型 类型大小(32位系统) 8位 16位 常量字符表示法 'A' L'A' 或 'A' 常量字符串表示法 'hello' L'hello' ...

  10. 往github上传代码忽略node_modules文件夹

    首先必须在你初始化  git 仓库的那个文件夹建立 .gitigonre 文件,在这个文件夹里面写入下面代码 node_modules npm-debug.log package-lock.json ...