一、定位方法

注意:元素属性必须唯一存在

#id定位
find_element_by_id()
#name定位
find_element_by_name()
#class_name定位
find_element_by_class_name()
#链接文本定位
find_element_by_link_text()
#部分链接文本定位
find_element_by_partial_link_text()
#xpath定位
find_element_by_xpath()
#css定位
find_element_by_css_selector()
#tag_name定位
find_element_by_tag_name()

#selenium By定位,使用这种用法前需要导入By类,如下:
from selenium.webdriver.common.by import By
#id定位
find_element(By.ID,value)
#name定位
find_element(By.NAME,value)
#class_name定位
find_element(By.CLASS_NAME,value)
#链接文本定位
find_element(By.LINK_TEXT,value)
#部分链接文本定位
find_element(By.PARTIAL_LINK_TEXT,value)
#xpath定位
find_element(By.XPATH,value)
#css定位
find_element(By.CSS_SELECTOR,value)
#tag_name定位
find_element(By.TAG_NAME,value)

1.id定位

#coding=utf-8

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_id("kw").send_keys("python")

2.name定位

#coding=utf-8

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_name("wd").send_keys("python")

3.class_name定位

#coding=utf-8

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_class_name("s_ipt").send_keys("python")

4.链接文本定位

#coding=utf-8

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_link_text("hao123").click()

5.部分链接文本定位

#coding=utf-8

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_partial_link_text("hao").click()

6.xpath定位

(1)直接复制页面中xpath

(2)相对路径(找祖籍)

  • 两个斜线(//)代表相对路径
  • 使用了通配符 * 表示匹配任意标签名
#coding=utf-8

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_xpath('//*[@class="s_ipt"]').send_keys("python")
#coding=utf-8

from selenium import webdriver
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
dr.find_element_by_xpath('//input[@class="s_ipt"]').send_keys("python")
#coding=utf-8

from selenium import webdriver
from time import sleep

dr =webdriver.Chrome()
dr.get("http://xxxxxxxx.com/")
dr.find_element_by_class_name("login").click()
title1 = dr.title
dr.find_element_by_xpath('//input[@placeholder="请输入手机号码" and @name="loginName"]').send_keys("1777982xxxx")
dr.find_element_by_name("loginPwd").send_keys("xxxxxxxx")
dr.find_element_by_xpath('//*[@class="login1"]/div[2]').click()
sleep(2)
title2 = dr.title
if title1 == title2:
    raise AssertionError
else:
    pass 

(3)绝对路径/层级定位

  • 从HTML元素DOM树从上至下一级一级查找
  • / 表示上下级
#coding=utf-8

from selenium import webdriver
import time
dr = webdriver.Chrome()
dr.get("http://192.168.0.161:8081/discuz/forum.php")
time.sleep(2)
dr.find_element_by_xpath("html/body/div[5]/div/div[1]/form/div/div/table/tbody/tr[1]/td[2]/input").send_keys("zhengying")

(4)相对路径结合绝对路径用法

#coding=utf-8

from selenium import webdriver
import time
dr = webdriver.Chrome()
dr.get("http://192.168.0.161:8081/discuz/forum.php")
time.sleep(2)
dr.find_element_by_xpath('//*[@id="lsform"]/div/div/table/tbody/tr[1]/td[2]/input').send_keys("zhengying")

7.css定位

css常用符号:

  • #  表示id
  • .  表示class
  • >  表示子元素,层级

(1)css中通过id定位

#coding=utf-8

from selenium import webdriver
import time
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
time.sleep(2)
dr.find_element_by_css_selector("#kw").send_keys("zhengying")

(2)css中通过class定位

#coding=utf-8

from selenium import webdriver
import time
dr = webdriver.Chrome()
dr.get("https://www.baidu.com")
time.sleep(2)
dr.find_element_by_css_selector(".s_ipt").send_keys(u"新方硕")

(3)通过其它属性定位

find_element_by_css_selector("[属性=‘属性值’]")

find_element_by_css_selector("[属性=属性值]") ---------------- 请注意这里属性值没有加引号
#coding=utf-8

from selenium import webdriver
import time
dr = webdriver.Chrome()
dr.get("http://192.168.0.161:8081/discuz/forum.php")
time.sleep(2)
dr.find_element_by_css_selector('[value="请输入搜索内容"]').send_keys(u"新方硕")

(4)通过父子关系定位:

  • 假如你不知道某人的身份证号码、名字、手机号码等信息时无法取得联系,但是你知道某人爸爸的手机号码,此时你可以通过他爸爸来找到某人。
  • 换成术语就是当我们定位元素时,发现没有可以标识的唯一的元素的属性值时,那我们可以考虑用父亲标签结合属性来定位元素。
  • css路径定位时,不能和xpath定位一样标注出第几个标签
#coding=utf-8

from selenium import webdriver
import time
dr = webdriver.Chrome()
dr.get("http://192.168.0.161:8081/discuz/forum.php")
time.sleep(2)
dr.find_element_by_css_selector('.scbar_txt_td > input').send_keys(u"新方硕")

(5)css的绝对路径定位

#coding=utf-8

from selenium import webdriver
import time
dr = webdriver.Chrome()
dr.get("http://192.168.0.161:8081/discuz/forum.php")
time.sleep(2)
dr.find_element_by_css_selector('html>body>div>div>div>form>div>div>table>tbody>tr>td>input').send_keys(u"新方硕")

python selenium八大定位方法的更多相关文章

  1. python selenium(定位方法)

    一.定位方法 注意:元素属性必须唯一存在 #id定位 find_element_by_id() #name定位 find_element_by_name() #class_name定位 find_el ...

  2. Python+Selenium自动化-定位一组元素,单选框、复选框的选中方法

    Python+Selenium自动化-定位一组元素,单选框.复选框的选中方法   之前学习了8种定位单个元素的方法,同时webdriver还提供了8种定位一组元素的方法.唯一区别就是在单词elemen ...

  3. Python+Selenium自动化-定位页面元素的八种方法

    Python+Selenium自动化-定位页面元素的八种方法   本篇文字主要学习selenium定位页面元素的集中方法,以百度首页为例子. 0.元素定位方法主要有: id定位:find_elemen ...

  4. python之selenium元素定位方法

    前提: 大家好,今天我们来学习一下selenium,今天主要讲解selenium定位元素的方法,希望对大家有所帮助! 内容: 一,selenium定位元素 selenium提供了8种方法: 1.id ...

  5. python+selenium元素定位——8种方法

    定位元素,selenium提供了8中元素定位方法: (1)find_element_by_id() :html规定,id在html中必须是唯一的,有点类似于身份证号 (2)find_element_b ...

  6. python selenium 元素定位(三)

    上两篇的博文中介绍了python selenium的环境搭建和编写的第一个自动化测试脚本,从第二篇的例子中看出来再做UI级别的自动化测试的时候,有一个至关重要的因素,那就是元素的定位,只有从页面上找到 ...

  7. Python Appium 元素定位方法简单介绍

    Python  Appium  元素定位 常用的八种定位方法(与selenium通用) # id定位 driver.find_element_by_id() # name定位 driver.find_ ...

  8. selenium 之定位方法

    1 id 定位 driver.find_element_by_id() HTML 规定id 属性在HTML 文档中必须是唯一的.这类似于公民的身份证号,具有很强的唯一性 from selenium i ...

  9. Python&Selenium智能等待方法封装

    摘要:本篇博文用几行代码展示Python和Selenium做自动化测试时常见的显示等待和封装 # 用于实现智能等待页面元素的出现 # encoding = utf-8 ""&quo ...

随机推荐

  1. 【446】Deep Learning

    ref: 深度学习基础介绍 机器学习19 神经网络NN算法 ref: 深度学习基础介绍 机器学习11 神经网络算法应用上 ref: 深度学习基础介绍 机器学习12 神经网络算法应用下 ref: 神经网 ...

  2. LODOP打印维护适应不同的客户端

    之前的博文:Lodop打印设计.维护.预览.直接打印简单介绍,介绍了打印设计.打印维护.打印预览,直接打印等的区别和使用. 如上面以前博文描述的,打印维护是针对客户端进行调整的,开放打印维护给客户端, ...

  3. [LeetCode] 90. Subsets II 子集合 II

    Given a collection of integers that might contain duplicates, nums, return all possible subsets (the ...

  4. 简单的Lock死锁例子

    static void Main(string[] args) { lock (_lock1) { var t = new Thread(() => { lock (_lock1) { Cons ...

  5. 第07组 Beta冲刺(4/4)

    队名:秃头小队 组长博客 作业博客 组长徐俊杰 过去两天完成的任务:学习了很多东西 Github签入记录 接下来的计划:继续学习 还剩下哪些任务:后端部分 燃尽图 遇到的困难:自己太菜了 收获和疑问: ...

  6. 8、2 es数据库的使用

    1.注意问题.es和redis同时使用会报错 解决: package com.bw; import org.springframework.beans.factory.InitializingBean ...

  7. GridView树状结构显示

    下面的树形结构代码需要GridVIew中的数据要求是按照上下级关系已经排列好的顺序,比如: GridView ID ParentID Name 1 0 父1 2 1 父1子1 3 1 父1子2 4 3 ...

  8. hdu 2841 题解

    题目 题意:就是问在一个$ n* m $的矩阵中站在 $ (0,0) $ 能看到几个整数点. 很明显如果有两个平行向量 $ \vec{a}=(x_1,y_1) $ ,$ \vec{b}=(x_2,y_ ...

  9. Python使用RMF聚类分析客户价值

    投资机构或电商企业等积累的客户交易数据繁杂.需要根据用户的以往消费记录分析出不同用户群体的特征与价值,再针对不同群体提供不同的营销策略. 用户分析指标 根据美国数据库营销研究所Arthur Hughe ...

  10. Nginx 配置 HTTP 跳转 HTTPS-Linux运维日志

    本文介绍 Nginx 访问 HTTP 跳转 HTTPS 的 4 种配置方式. rewrite Nginx rewrite 有四种 flag: break:在一个请求处理过程中将原来的 url 改写之后 ...