一、web页面元素定位工具介绍

1、打开google浏览器,按F12进入开发者模式,如下图:

2、用鼠标点击下图红色框中的箭头——然后鼠标移动到web页面的元素上(此处为百度框),会自动定位到对应的html代码,如下图:

二、web页面元素的8种定位方法:

1、通过元素的id属性来定位元素——id是唯一标识(每个id都是不一样的)

driver.find_element_by_id("kw")

 

1 from selenium import webdriver
2 driver=webdriver.Chrome()
3 driver.get("https://www.baidu.com/")
4
5 # 通过元素的id属性来定位——id是唯一的
6 search=driver.find_element_by_id("kw")
7
8 search.send_keys("selenium")

id.py

2、通过元素的name属性来定位元素,name属性不是绝对唯一的(一个页面内可能存在多个元素的name属性是相同的)

如果name属性的值wd是唯一的,用find_element_by_name定位元素,返回值是一个值
     driver.find_element_by_name("wd")

如果name属性的值wd不是唯一的,用find_elements_by_name定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
     driver.find_elements_by_name("wd")

 

 1 from selenium import webdriver
2 driver=webdriver.Chrome()
3 driver.get("https://www.baidu.com/")
4
5 #通过元素的name属性来定位元素,name属性不是绝对唯一的(一个页面内可能存在多个元素的name属性是相同的)
6
7 # 如果name属性的值kw是唯一的,用find_element_by_name定位元素,返回值是一个值
8 search=driver.find_element_by_name("wd")
9
10 # 如果name属性的值kw不是唯一的,用find_elements_by_name定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
11 search=driver.find_elements_by_name("wd")
12
13
14 search.send_keys("python")

name.py

3、通过元素的class属性来定位元素,class属性不是绝对唯一的(一个页面内可能存在多个元素的class属性是相同的)

如果class属性的值s_ipt是唯一的,用find_element_by_class_name定位元素,返回值是一个值

driver.find_element_by_class_name("s_ipt")

如果class属性的值s_ipt不是唯一的,用find_elements_by_class_name定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
      driver.find_elements_by_class_name("s_ipt")

 

 1 from selenium import webdriver
2 driver=webdriver.Chrome()
3 driver.get("https://www.baidu.com/")
4
5 #通过元素的class属性来定位元素,class属性不是绝对唯一的(一个页面内可能存在多个元素的class属性是相同的)
6
7 # 如果class属性的值s_ipt是唯一的,用find_element_by_class定位元素,返回值是一个值
8 search=driver.find_element_by_class_name("s_ipt")
9
10 # 如果class属性的值s_ipt不是唯一的,用find_elements_by_class定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
11 search=driver.find_elements_by_class_name("s_ipt")
12
13
14 search.send_keys("java")

class.py

4、通过元素的标签名tag来定位元素,标签名不是绝对唯一的(一个页面内可能存在多个相同的标签名)

如果标签名是唯一的,用find_element_by_tag_name定位元素,返回值是一个值
     driver.find_element_by_tag_name("input")

如果标签名不是唯一的,用find_elements_by_tag_name定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
     driver.find_elements_by_tag_name("input")

要找的元素是第8个input标签,所以通过列表查找时下标是7

      search2[7].send_keys("java")

备注:上图找到的是15个标签,不是13个

 

 1 from selenium import webdriver
2 driver=webdriver.Chrome()
3 driver.get("https://www.baidu.com/")
4
5 #通过元素的标签名来定位元素,标签名不是绝对唯一的(一个页面内可能存在多个相同的标签名)
6
7 # 如果标签名是唯一的,用find_element_by_tag_name定位元素,返回值是一个值
8 #search=driver.find_element_by_tag_name("input")
9
10 # 如果标签名不是唯一的,用find_elements_by_tag_name定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
11 search2=driver.find_elements_by_tag_name("input")
12
13 #打印出15个元素
14 print(search2)
15
16 #要找的元素是第8个input标签,所以通过列表查找时下标是7
17 search2[7].send_keys("java")

input

 5&6、通过链接元素的文本内容来精确匹配和模糊匹配定位元素,不是绝对唯一的(一个页面内可能存在多个链接元素的文本内容是相同的)

1、精确匹配——文本内容为“新闻”

如果文本内容时唯一的,用find_element_by_link_text定位元素,返回值是一个值
            driver.find_element_by_link_text("新闻")

如果文本内容不是唯一的,用elements_by_link_text定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
           driver.find_elements_by_link_text("新闻")

2、模糊匹配——通过文本内容的部分内容,例如“hao123”,通过“hao”定位

如果文本内容时唯一的,用find_element_by_partial_link_text定位元素,返回值是一个值
            driver.find_element_by_partial_link_text("hao123")

如果文本内容不是唯一的,用find_elements_by_partial_link_text定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表

driver.find_elements_by_partial_link_text("hao123")

 

 1 # 1、精确匹配——文本内容为“新闻”
2 # 如果文本内容时唯一的,用find_element_by_link_text定位元素,返回值是一个值
3 search=driver.find_element_by_link_text("新闻")
4
5 # 如果文本内容不是唯一的,用elements_by_link_text定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
6 search=driver.find_elements_by_link_text("新闻")
7
8 search.click()
9
10 # 2、模糊匹配——通过文本内容的部分内容,例如“hao123”,通过“hao”定位
11 # 如果文本内容时唯一的,用find_element_by_partial_link_text定位元素,返回值是一个值
12 aa=driver.find_element_by_partial_link_text("hao123")
13
14 # 如果文本内容不是唯一的,用find_elements_by_partial_link_text定位元素,返回符合条件的多个值,保存在列表中,即返回的是列表
15
16 aa=driver.find_elements_by_partial_link_text("hao123")

linktext

 7、通过Xpath定位

1、绝对路径定位方法如下图:

find_element_by_xpath("/html/body/div[2]/div/form/div/input")——以/开头,从根目录逐级查找(父子关系),这种方式太依赖元素的位置和顺序,稍微调整就会找不到,后期维护成本太高,所以一般不会用绝对定位

2、相对定位——以//开头,在整个页面中寻找符合定位表达式的元素,不在乎元素的顺序和位置

单属性定位: //标签名[@属性名称=值]

如果单属性定位不到,就需要组合属性定位://标签名[@属性名称=值 and @属性名称=值 and @属性名称=值]

如果页面存在2个一模一样的元素,只是位置不同,定位方式如下图:从父类开始找,父类还不能唯一确定,继续从父类的父类就找

转载于:https://www.cnblogs.com/yhms/p/10728765.html

二、appium-app元素定位

Appium-app有5种元素定位方式:

1、通过id定位元素:resrouce-id

2、通过className定位:classname   (类名)

3、通过accessibility定位:content-desc  ()

4、通过androiduiautomator定位 (uiselector)

5、通地xpath定位

Xpath,id,class,accessibility id,-android uiautomator

在appium-app中xpath定位方式不常用

web元素定位和appium-app元素定位的更多相关文章

  1. 【转】Appium如何定位安卓APP元素

    转载原文:https://www.jianshu.com/p/efe9dcf8bbaf 一.定位工具 在安装appium环境的时候我们已经安装了SDK,里面就自带有元素定位的工具,位置在.../sdk ...

  2. Appium Android 元素定位方法 原生+H5

    APPIUM Android 定位方式   1.定位元素应用元素 1.1通过id定位元素 Android里面定位的id一般为resrouce-id: 代码可以这样写: WebElement eleme ...

  3. XP定位(APP元素定位)

    Appium app自动化测试经验分享-Xpath定位总结 在我看来,自动化测试中元素定位的倚天剑和屠龙刀莫过于 Xpath和CSS,但CSS只用于Web(之前已经分享过),这次就分享下Xpath的定 ...

  4. Appium + Python -------------元素定位

    说在前面 1.https://github.com/appium/python-client/tree/master/test  里面有一些test ,可以看看,研究研究 2.学会使用 uiautom ...

  5. appium 使用findElementByAndroidUIAutomator 定位元素示例

    appium 使用findElementByAndroidUIAutomator 定位元素示例 import io.appium.java_client.remote.MobileCapability ...

  6. Appium之xpath定位元素

    原文:http://www.cnblogs.com/cnkemi/p/9180525.html appium也是以webdriver为基的,对于元素的定位也基本一致,只是增加一些更适合移动平台的独特方 ...

  7. Appium Desktop 元素定位和脚本录制功能

    Appium Desktop除了可以做Server之外还可以进行元素定位和脚本录制功能,点击放大镜按钮,进入页面设置.开始配置Desired Capabilities. 配置Desired Capab ...

  8. APP元素定位和操作

    webdriver 提供了八种元素定位方法: 在 Python 语言中对应的定位方法如下:find_element_by_id()find_element_by_name()find_element_ ...

  9. CSS3-基于浮动的布局,响应式WEB设计,定位网页上的元素,设计打印页面的css技术

    基于浮动的布局: 1.除非图片设置了宽度,否则始终应该要对浮动的图片设置一个宽度,这样可以让浏览器给其他内容腾出环绕的空间 2.当侧边栏的高度与主内容区的高度不一致的时候,可以用个margin进行调整 ...

  10. 初探appium之元素定位(1)

    无论是selenium还是appium,元素定位都是我们开始实现自动化面临的第一个问题.selenium还好,我们可以在浏览器的调试页面进行元素定位还是蛮方便的.那么appium怎么做呢? 我看到很多 ...

随机推荐

  1. this作为构造函数时注意点

    在 JS 中,为了实现类,我们需要定义一些构造函数,在调用一个构造函数的时候加上 new 这个关键字: function Person(name) { this.name = name; consol ...

  2. qq 表情库

    ![/qq](https://cdn.luogu.com.cn/upload/pic/62224.png) ![/cy](https://cdn.luogu.com.cn/upload/pic/622 ...

  3. NOI2020网上同步赛 游记

    Day1 预计得分:\(32pts\)(我裂开了--) T1 美食家 表示考试的时候想到了关于矩阵快速幂的想法,甚至连分段后怎么处理都想好了,但是没有想到拆点,还有不知道怎么处理重边(这个考虑是多余的 ...

  4. Angular:使用前端proxy代理解决跨域问题

    ①在项目文件的根目录下新建文件proxy.config.json { "/": { "target": "http://127.0.0.1:3000& ...

  5. Java经典小游戏——贪吃蛇简单实现(附源码)

    一.使用知识 Jframe GUI 双向链表 线程 二.使用工具 IntelliJ IDEA jdk 1.8 三.开发过程 3.1素材准备 首先在开发之前应该准备一些素材,已备用,我主要找了一个图片以 ...

  6. 跨站点脚本编制 - SpringBoot配置XSS过滤器(基于Jsoup)

    1. 跨站点脚本编制   风险:可能会窃取或操纵客户会话和 cookie,它们可能用于模仿合法用户,从而使黑客能够以该用户身份查看或变更用户记录以及执行事务.   原因:未对用户输入正确执行危险字符清 ...

  7. Docker部署Portainer搭建轻量级可视化管理UI

    1. 简介   Portainer是一个轻量级的可视化的管理UI,其本身也是运行在Docker上的单个容器,提供用户更加简单的管理和监控宿主机上的Docker资源. 2. 安装Docker   Doc ...

  8. Validated 注解完成 Spring Boot 参数校验

    1.  @Valid 和 @Validated @Valid 注解,是 Bean Validation 所定义,可以添加在普通方法.构造方法.方法参数.方法返回.成员变量上,表示它们需要进行约束校验. ...

  9. 【开源】基于 SpringBoot 的 web kettle 在线采集平台

    kettle-scheduler-boot 开发计划 序号 项目 状态 优先级 1 在线管理,编辑kettle脚本 紧急 2 通过源码实现集群,多线程执行任务 紧急 2 重构jpa部分,改为mybat ...

  10. IDEA将Java Web项目打war包

    准备工作 1.IntelliJ IDEA开发工具 2.可以正常运行的Java Web项目 打war包流程 1.使用快捷键Ctrl+Alt+Shift+s 或者 鼠标点击选中项目名按F4 打开 Proj ...