Python+Selenium有以下八种定位元素的方法:

1. find_element_by_id()

eg: find_element_by_id("kw")

2. find_element_by_name()

eg: find_element_by_name("wd")

3. find_element_by_class_name()

eg: find_element_by_class_name("bg s_btn")

4. find_element_by_tag_name()

eg: find_element_by_tag_name("input")   -- 一般页面上重复标签比较多,所以很难通过标签名去区分不同的元素

5. find_element_by_link_text()

eg: find_element_by_link_text("hao123")

eg: find_element_by_link_text(u"新闻")   -- 在中文前面加个小“u”可以有效的避免中文乱码的问题

6. find_element_by_partial_link_text()

eg: find_element_by_partial_link_text("一个很长的文本的一部分")   -- 如果一个文本链接很长,可以只取其中一部分

7. find_element_by_xpath()

eg: find_element_by_xpath("/html/body/div/div[2]/div/div/div/from/span[2]/input")   -- 通过绝对路径定位

eg: find_element_by_xpath("//input[@autocomplete='off']")   -- 通过元素任意属性定位

eg: find_element_by_xpath("//*[@class='bg s_btn']")   -- 如果不想指定标签名也可以用星号(*)代替

eg: find_element_by_xpath("//form[@id='form']/span[2]/input")   -- 通过层级和属性定位

eg: find_element_by_xpath("//input[@id='kw' and @class='su']/span/input")   -- 可以使用逻辑运算符

8. find_element_by_css_selector()

eg: find_element_by_css_selector(".s_ipt")   -- 通过class属性定位

eg: find_element_by_css_selector("#kw")   -- 通过id属性定位

eg: find_element_by_css_selector("input")   -- 通过标签名定位

eg: find_element_by_css_selector("span>input")   -- 通过父子关系定位

eg: find_element_by_css_selector("input[autocomplete='off']")   -- 通过属性定位

eg: find_element_by_css_selector("span.bg s_btn_wr>input#su")   -- 组合定位

用By定位元素:

在使用 By 时需要将 By 类导入

from selenium.webdriver.common.by import By

find_element(By.ID,"kw")

find_element(By.NAME,"wd")

find_element(By.CLASS_NAME,"s_ipt")

find_element(By.TAG_NAME,"input")

find_element(By.LINK_TEXT,u"新闻")

find_element(By.PARTIAL_LINK_TEXT,u"新")

find_element(By.XPATH,"//*[@class='bg s_btn']")

find_element(By.CSS_SELECTOR,"span.bg s_btn_wr>input#su")

Python+Selenium定位元素的方法的更多相关文章

  1. python+selenium 定位元素的主要方法

    selenium对web各元素的操作首先就要先定位元素,定位元素的方法主要有以下几种: 通过id定位元素:find_element_by_id("id_vaule") 通过name ...

  2. Python Selenium定位元素常用解决办法

       在做web应用的自动化测试时,定位元素是必不可少的,这个过程经常会碰到定位不到元素的情况(报selenium.common.exceptions.NoSuchElementException), ...

  3. selenium定位元素的方法

    1.id定位: find_element_by_id() 从上面定位到的搜索框属性中,有个id="kw"的属性,我们可以通过这个id定位到这个搜索框 代码: # coding = ...

  4. 【selenium学习笔记一】python + selenium定位页面元素的办法。

    1.什么是Selenium,为什么web测试,大家都用它? Selenium设计初衷就是为web项目的验收测试再开发.内核使用的是javaScript语言编写,几乎支持所以能运行javaScript的 ...

  5. python + selenium定位页面元素的办法

    1.什么是Selenium,为什么web测试,大家都用它? Selenium设计初衷就是为web项目的验收测试再开发.内核使用的是javaScript语言编写,几乎支持所以能运行javaScript的 ...

  6. Web自动化基础(一)使用Selenium定位元素

    什么是元素?我们知道网页上有什么内容显示出来,比如一个按钮,一个输入框,一张图片,都可以理解成元素,这些元素是由html代码构成的,比如图片可以用<img>标签来展示,一个输入框可以用&l ...

  7. selenium 定位元素可以用多个findElement

    selenium 定位元素可以用多个findElement,如driver.findElement(By.id"XXX").findElement(By.linkText(XXX) ...

  8. python中列表元素连接方法join用法实例

    python中列表元素连接方法join用法实例 这篇文章主要介绍了python中列表元素连接方法join用法,实例分析了Python中join方法的使用技巧,非常具有实用价值,分享给大家供大家参考. ...

  9. python + selenium 练习篇 - 定位元素的方法

    1.利用ID定位元素(能直接通过ID来定位的元素比较少) # coding=utf-8from selenium import webdriverdriver = webdriver.Chrome() ...

随机推荐

  1. 编写高质量代码改善C#程序的157个建议——建议12: 重写Equals时也要重写GetHashCode

    建议12: 重写Equals时也要重写GetHashCode 除非考虑到自定义类型会被用作基于散列的集合的键值:否则,不建议重写Equals方法,因为这会带来一系列的问题. 如果编译上一个建议中的Pe ...

  2. How Tomcat Works(十九)

    本文重点关注启动tomcat时会用到的两个类,分别为Catalina类和Bootstrap类,它们都位于org.apachae.catalina.startup包下:Catalina类用于启动或关闭S ...

  3. DFS小题

    原创 题目为:()()()+()()()=()()() 将1~9这9个数字填入括号,每个数字只能用一次. 枚举: public class Test { public static void main ...

  4. ICallbackEventHandler使用

    后端:页面需继承ICallbackEventHandler protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack ...

  5. webapi put 请求405问题

    put 请求的时候  浏览器会像服务器发送两个请求 如何没做任何配置第一个options请求是会报错的 这是需要配置路由给options作响应 这时options请求就通过了,然后你们会看到你的put ...

  6. C++内存管理之shared_ptr

     ----------------------------------------shared_ptr--------------------------------------- 引子 c++中动态 ...

  7. Android学习笔记 Toast屏幕提示组件的使用方法

    activity_main.xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android&qu ...

  8. 倍增求lca(模板)

    定义LCA,最近公共祖先,是指一棵树上两个节点的深度最大的公共祖先.也可以理解为两个节点之间的路径上深度最小的点.我们这里用了倍增的方法求了LCA.我们的基本的思路就是,用dfs遍历求出所有点的深度. ...

  9. kali linux之xss

    攻击web客户端 客户端脚本语言(弹窗,广告,在浏览器中执行,javascript) javascript--与java语言无关,使用最广的客户端脚本语言 xss(cross-site scripti ...

  10. 百度分享,简单的一步操作解决你的网站不支持https访问的问题!

    百度分享,应该是目前最好用的前端分享插件了.然而,官方却没有支持https.现在越来越多的网站都走入https的安全加密队列了,那么在找不到更好地替代品的情况下,怎么能让它支持https呢? 答案当然 ...