一.环境配置

1.selenium下载安装

安装一:pip install selenium(多数会超时安装失败)

安装二:pip install -i https://pypi.tuna.tsinghua.edu.cn/simple selenium(使用清华园镜像下载)

2.webdriver下载

下载地址:http://chromedriver.storage.googleapis.com/index.html(谷歌为例)

下载时选择与当前谷歌浏览器版本一致或相近的版本去下载,下载完成后解压到python解释器目录下

二.八大元素

1.ID

ID具有唯一性,若是当前标签含有id属性,可以优先使用id定位。

from selenium import webdriver
from time import sleep from selenium.webdriver.common.by import By driver = webdriver.Chrome() # 实例化浏览器对象
driver.get('https://www.bing.com') # 设置跳转网页
driver.find_element(by=By.ID, value='sb_form_q').send_keys('我是好人') # id定位
sleep(3) # 等待3s
driver.quit() # 关闭网页

by表示当前使用什么元素定位,我们可以进入By模块里可以看到By类下的八种属性,value表示当前

属性的值,send_keys赋值。

2.NAME

name属性不唯一,一个页面可能有多个相同的name值,所以使用时要确保该属性值是唯一的

driver_name = driver.find_element(by=By.NAME, value='q')
driver_name.send_keys("作者是帅哥")

3.CLASS_NAME

driver_name = driver.find_element(by=By.CLASS_NAME, value='sb_form_q')
driver_name.send_keys("作者是帅哥")

4.LINK_TEXT

用于<a>标签定位

driver_name = driver.find_element(by=By.LINK_TEXT, value='文案')
driver_name.click() # click点击事件

value的值要和<a>文案</a>的值相等,click()点击超链接

5.PARTIAL_LINK_TEXT

PARTIAL_LINK_TEXT与LINK_TEXT相似,都是用于超链接,区别在于前置value为模糊查询,后者匹配相等

driver_name = driver.find_element(by=By.LINK_TEXT, value='案')
driver_name.click() # click点击事件

6.TAG_NAME

用于标签定位(<a>,<p>,<input>....),该元素定位不常用,效率低

driver_name = driver.find_element(by=By.TAG_NAME, value='input')
driver_name.send_keys("作者是帅哥")

7.XPATH

(1)可理解为元素路径定位,内含两种定位,绝对路径和相对路径

  • 绝对路径:以/html开头
  • 相对路径:以//*开头
  driver.find_element(by=By.XPATH, value="//*[@id='sb_form_q' and @name='q']").send_keys("作者是帅哥") #相对路径
  driver.find_element(by=By.XPATH, value="/html/body/div[2]/div/div[3]/div[2]/form/div[1]/input").send_keys("作者是帅哥") #相对路径

  相对路径下[]内可连接多个and条件。这就可以解决因为name值相等元素定位错误的问题,前提需保证你定

位的标签中有这些属性。层级结构非常复杂时,手动输入路径可能会出错,这个时候我们可直接复制即可

(2)XPATH用法拓展(适用于相对路径)

  • contains用法
  driver.find_element(by=By.XPATH, value="//*[contains(@name,'na') and (@id,'sb_form_q')]").send_keys("作者说帅哥")

   [contains(@属性,"属性值")]:模糊匹配

  • starts-with用法
  driver.find_element(by=By.XPATH, value="//*[starts-with(@name,'2') and contains(@id,'2')]").send_keys("12")

   [starts-with(@属性,"属性值")]:匹配以XXX开头

8.CSS_SELECTOR

(1)层级语法定位

  driver.find_element(by=By.CSS_SELECTOR, value="copy selector").click()

   

  层级定位可直接copy selector即可

(2)选择器定位

  • id选择器
   driver.find_element(by=By.CSS_SELECTOR, value="#sb_form_q").click()

    这里需要在value值前加个#

  • class选择器

   driver.find_element(by=By.CSS_SELECTOR, value="[class='sb_form_q']").send_keys("class选择器") #精准匹配

  • 属性选择器

    语法一:value="[属性='属性值']"

    driver.find_element(by=By.CSS_SELECTOR, value="[name='q']").send_keys("属性选择器")

    driver.find_element(by=By.CSS_SELECTOR, value="[id='sb_form_q']").send_keys("属性选择器")

    语法二:value="标签[属性=‘属性值’]"

    driver.find_element(by=By.CSS_SELECTOR, value="a[id='halou']").click()

(3)CSS_SELECTOR拓展

  • 匹配以XX开头:value="[id^='head']")
  • 匹配以XX结尾:value="[id$='tail']"
  • 模糊匹配:valur="[name*='like']"

三.find_element与find_elements区别

我们在使用find_element和find_elements获取定位元素时,后者返回的是list集合类型的,

前者返回的是<class 'selenium.webdriver.remote.webelement.WebElement'> 类型。

  • find_element:适用于获取唯一的定位元素值(默认返回第一个)
  • find_elements:适用于获取多个值相同的元素定位(默认返回第一个,我们可用对应的下标来获取)

selenium环境配置和八大元素定位的更多相关文章

  1. Java + Selenium + WebDriver八大元素定位方式

    UI自动化测试的第一步就是进行元素定位,下面给大家介绍一下Selenium + WebDriver的八大元素定位方式.现在我们就以百度搜索框为例进行元素定位,如下图: 一.By.name() Java ...

  2. selenium八大元素定位方法

    1.ID定位 可以根据元素的id来定位属性,id是当前整个HTML页面中唯一的,所以可以通过id属性来唯一定位一个元素,是首选的元素定位方式.(动态ID不做考虑) # 导入webdriver和By f ...

  3. C# selenium环境配置

    1.下载C#selenium     selenium官网:  http://www.seleniumhq.org/download/   下载后解压:     打开net35后,将里面的dll文件添 ...

  4. Selenium:WebDriver简介及元素定位

    参考内容:官方API文档,下载链接:http://download.csdn.net/detail/kwgkwg001/4004500 虫师:<selenium2自动化测试实战-基于python ...

  5. Python3+Selenium环境配置

    一.所需工具 1.Python3.6安装包 2.Selenium安装包(selenium-server-standalone-3.8),如果是Python3的话可以不用下载selenium压缩包,Py ...

  6. python+selenium环境配置及浏览器调用

    最近在学习python自动化,从项目角度和技术基础角度出发,我选择了python+selenium+appium的模式开始我的自动化测试之旅: 一.python安装 二.python IDE使用简介 ...

  7. 跟浩哥学自动化测试Selenium -- 浏览器的基本操作与元素定位(3)

    浏览器的基本操作与元素定位 通过上一章学习,我们已经学会了如何设置驱动路径,如何创建浏览器对象,如何打开一个网站,接下来我们要进行一些复杂的操作比如先打开百度首页,在打开博客园,网页后退,前进等等,甚 ...

  8. 【转】【selenium+Python WebDriver】之元素定位不到解决办法

    感谢: 煜妃的<Python+Selenium定位不到元素常见原因及解决办法(报:NoSuchElementException)> ClassName定位报错问题:<[Python] ...

  9. 【转载】【selenium+Python WebDriver】之元素定位

    总结: 感谢: “煜妃”<Selenuim+Python之元素定位总结及实例说明> “Huilaojia123”<selenium WebDriver定位元素学习总结> “上海 ...

随机推荐

  1. Spring注解开发_Spring容器创建概述

    浅尝Spring注解开发_Spring容器创建概述 浅尝Spring注解开发,基于Spring 4.3.12 概述Spring容器创建的过程,包括12个方法的执行 浅尝Spring注解开发_自定义注册 ...

  2. 扩展.Net Core Identity Server 授权方式,实现 手机号+ 验证码 登录

    背景 国内来讲,注册/登录流程都是尽可能的简单,注册流程复杂,容易流失客户.手机号 + 短信验证码的方式非常普遍:但是框架默认并没有类似的功能,需要我们自己进行扩展. 思路 验证登录手机号为注册用户, ...

  3. 【机器学习基础】无监督学习(3)——AutoEncoder

    前面主要回顾了无监督学习中的三种降维方法,本节主要学习另一种无监督学习AutoEncoder,这个方法在无监督学习领域应用比较广泛,尤其是其思想比较通用. AutoEncoder 0.AutoEnco ...

  4. JUC自定义线程池练习

    JUC自定义线程池练习 首先上面该线程池的大致流程 自定义阻塞队列 首先定义一个双向的队列和锁一定两个等待的condition 本类用lock来控制多线程下的流程执行 take和push方法就是死等, ...

  5. CentOS6.x静默安装Oracle12c

    一.准备 1.1 安装环境 系统要求 内存 > 2G 安装目录空间 > 6.5G /tmp目录空间 > 1G 操作系统 cat /etc/redhat-release 用rpm命令确 ...

  6. 150. Evaluate Reverse Polish Notation - LeetCode

    Question 150. Evaluate Reverse Polish Notation Solution 2 1 + 3 * 是((2+1)*3)的后缀(postfix)或逆波兰(reverse ...

  7. PostGIS 扩展创建失败原因调查

    Issue 升级 PostgreSQL 9.1 的一个集群,由于该集群用到了 PostGIS,在升级 PostgreSQL 时也需要升级一下 PostGIS.PostGIS 相关软件安装好后,在 Po ...

  8. awk-文本处理【中文手册版】

    01. 简介 AWK是一个文本(面向行和列)处理工具,同时它也是一门脚本语言. AWK其名称得自于它的创始人 Alfred Aho .Peter Weinberger 和 Brian Kernigha ...

  9. v86.01 鸿蒙内核源码分析 (静态分配篇) | 很简单的一位小朋友 | 百篇博客分析 OpenHarmony 源码

    本篇关键词:池头.池体.节头.节块 内存管理相关篇为: v31.02 鸿蒙内核源码分析(内存规则) | 内存管理到底在管什么 v32.04 鸿蒙内核源码分析(物理内存) | 真实的可不一定精彩 v33 ...

  10. DOM树

    一.DOM树一共有12种节点类型,常用的有4种: 1.Document类型(document节点)--DOM的"入口点" 2.Element节点(元素节点)--HTML标签,树构建 ...