Python+selenium web自动化测试知识点合集2

选择元素

对于百度搜索页面,如果我们想自动化输入“selenium”,怎么做呢?

这就是在网页中,操控界面元素。

web界面自动化,要操控元素,首先需要 选择 界面元素 ,或者说 定位 界面元素

就是 先告诉浏览器,你要操作哪个界面元素, 让它找到你要操作的界面元素。

我们必须要让浏览器 先找到元素,然后,才能操作元素

选择元素的基本方法

对应web自动化来说, 就是要告诉浏览器,你要操作的界面元素是什么。

那么,怎么告诉浏览器呢?

方法就是:告诉浏览器,你要操作的这个 web 元素的特征。

就是告诉浏览器,这个元素它有什么与众不同的地方,可以让浏览器一下子找到它。

元素的特征怎么查看?

可以使用浏览器的开发者工具栏帮我们查看、选择 web 元素。点击F12出现开发者工具栏,我们要找的就是对应的html元素

一、根据id属性选择元素

把 id 想象成元素的编号, 是用来在html中标记该元素的。

根据规范, 如果元素有id属性 ,这个id 必须是当前html中唯一的。

所以如果元素有id, 根据id选择元素是最简单高效的方式。

from selenium import  webdriver
from selenium.webdriver.chrome.service import Service
from selenium.webdriver.common.by import By
###创建一个控制浏览器的对象
###创建WebDriver类型的实例对象
wb = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))# 调用WebDriver 对象的get方法 可以让浏览器打开指定网址
wb.get('https://www.baidu.com')
###根据Id选择元素,返回的就是该元素对应的WebElement对象
element = wb.find_element(By.ID,'kw')
element.send_keys('selenium\n')

如果我们在这里

element.send_keys('selenium\n')

 不使用回车来输入的话,可以通过先输入再点击,进行操作。“百度一下”的元素属性如下:

 

from selenium import  webdriver
from selenium.webdriver.chrome.service import Service
from selenium.webdriver.common.by import By
###创建一个控制浏览器的对象
###创建WebDriver类型的实例对象
wb = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))# 调用WebDriver 对象的get方法 可以让浏览器打开指定网址
wb.get('https://www.baidu.com')
###根据Id选择元素,返回的就是该元素对应的WebElement对象
element = wb.find_element(By.ID,'kw')
element.send_keys('selenium')element = wb.find_element(By.ID,'su')
element.click()

  二、根据class选择元素

 所有的植物元素都有个class属性 值为 plant。

所有的动物元素都有个class属性 值为 animal。

如果我们要选择 所有的 动物:使用 find_elements,如果没有符合条件的则返回空列表

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Service
# 创建 WebDriver 实例对象,指明使用chrome浏览器驱动
###创建WebDriver类型的实例对象
wd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))# WebDriver 实例对象的get方法 可以让浏览器打开指定网址
wd.get('https://cdn2.byhy.net/files/selenium/sample1.html')# 根据 class name 选择元素,返回的是 一个列表
# 里面 都是class 属性值为 animal的元素对应的 WebElement对象
elements = wd.find_elements(By.CLASS_NAME, 'animal')# 取出列表中的每个 WebElement对象,打印出其text属性的值
# text属性就是该 WebElement对象对应的元素在网页中的文本内容
for element in elements:print(element.text)

find_elements不同,find_element 返回的就是第一个class 属性为 animal的元素,如果没有符合条件的则抛出异常。

三、根据tag选择元素

我们可以通过指定 参数为 By.TAG_NAME ,选择所有的tag名为 div的元素。

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))wd.get('https://cdn2.byhy.net/files/selenium/sample1.html')# 根据 tag name 选择元素,返回的是 一个列表
# 里面 都是 tag 名为 div 的元素对应的 WebElement对象
elements = wd.find_elements(By.TAG_NAME, 'div')# 取出列表中的每个 WebElement对象,打印出其text属性的值
# text属性就是该 WebElement对象对应的元素在网页中的文本内容
for element in elements:print(element.text)

四、通过WebElement对象选择元素

不仅 WebDriver对象有 选择元素 的方法, WebElement对象 也有选择元素的方法。

WebElement对象 也可以调用 find_elements, find_element 之类的方法

WebDriver 对象 选择元素的范围是 整个 web页面, 而WebElement 对象 选择元素的范围是该元素的内部。前三种方法都是通过WebDriver实例化然后选择元素。

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))wd.get('https://cdn2.byhy.net/files/selenium/sample1.html')element = wd.find_element(By.ID,'container')# 限制 选择元素的范围是 id 为 container 元素的内部。
spans = element.find_elements(By.TAG_NAME, 'span')
for span in spans:print(span.text)

 五、等待元素出现

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))wd.get('https://www.byhy.net/_files/stock1.html')element = wd.find_element(By.ID, 'kw')element.send_keys('通讯\n')# 返回页面 ID为1 的元素
element = wd.find_element(By.ID,'1')
# 打印该元素的文字内容
print(element.text)

在我们进行网页操作的时候, 有的元素内容不是可以立即出现的, 可能会等待一段时间。

比如 我们的股票搜索示例页面, 搜索一个股票名称, 我们点击搜索后, 浏览器需要把这个搜索请求发送给服务器, 服务器进行处理后,再把搜索结果返回给我们,这个搜索结果可能会有很多,所以,从点击搜索到得到结果,需要一定的时间,只是通常 服务器的处理比较快,我们感觉好像是立即出现了搜索结果。

也就是说点击查询之后,网站还没有来得及返回搜索结果,就执行了以下代码:


# 返回页面 ID为1 的元素
element = wd.find_element(By.ID,'1')

这样的话就找不到这个id为1的元素,就会报错:

selenium.common.exceptions.NoSuchElementException: Message: no such element: Unable to locate element: {"method":"css selector","selector":"[id="1"]"}

也就是说:网站还没有搜索完,这个代码就执行完了,响应时间赶不上代码执行速度 。

怎么解决这个问题?

在搜索id元素之前添加两行代码:

import time
time.sleep(1)
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))wd.get('https://www.byhy.net/_files/stock1.html')element = wd.find_element(By.ID, 'kw')element.send_keys('通讯\n')
import time
time.sleep(1)# 返回页面 ID为1 的元素
element = wd.find_element(By.ID,'1')
# 打印该元素的文字内容
print(element.text)

也可以使用selenium中的implicitly_wait隐式等待方法。

当发现元素没有找到的时候, 并不立即返回 找不到元素的错误。

而是周期性(每隔半秒钟)重新寻找该元素,直到该元素找到,

或者超出指定最大等待时长,这时才 抛出异常(如果是 find_elements 之类的方法, 则是返回空列表)。

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))
wd.implicitly_wait(10)wd.get('https://www.byhy.net/_files/stock1.html')element = wd.find_element(By.ID, 'kw')element.send_keys('通讯\n')
# import time
# time.sleep(1)# 返回页面 ID为1 的元素
element = wd.find_element(By.ID,'1')
# 打印该元素的文字内容
print(element.text)
wd.implicitly_wait(10)

该方法接受一个参数, 用来指定最大等待时长。

操控元素的基本方法 

  • 点击元素  

    element.click()
  • 在元素中输入字符串,通常是对输入框这样的元素 

    element.send_keys('selenium')
  • 获取元素包含的信息,比如文本内容

    for element in elements:print(element.text)

 这三种都是上面已经学过的。

如果我们要 把输入框中已经有的内容清除掉,可以使用WebElement对象的clear方法。

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))
wd.implicitly_wait(10)wd.get('https://www.byhy.net/_files/stock1.html')element = wd.find_element(By.ID, 'kw')element.send_keys('通讯\n')
# import time
# time.sleep(1)
element.clear()element = wd.find_element(By.ID, 'kw')element.send_keys('科技\n')input()

获取元素的文本内容

通过上面的内容,我们知道通过WebElement对象的 text 属性,可以获取元素 展示在界面上的 文本内容。

element = wd.find_element(By.ID, 'animal')
print(element.text)

获取元素属性

不在页面上的怎么办?

通过WebElement对象的 get_attribute 方法来获取元素的属性值

比如要获取元素属性class的值,就可以使用 element.get_attribute('class')

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))
wd.implicitly_wait(10)wd.get('https://www.byhy.net/_files/stock1.html')element = wd.find_element(By.ID, 'kw')element.send_keys('通讯\n')
# import time
# time.sleep(1)# 返回页面 ID为1 的元素
element = wd.find_element(By.ID,'1')
# 打印该元素的文字内容
print(element.text)
#####获取属性
print(element.get_attribute('class'))

 获取整个元素对应的HTML

from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.chrome.service import Servicewd = webdriver.Chrome(service=Service(r'D:\GoogleDownload\chromedriver-win64\chromedriver-win64\chromedriver.exe'))
wd.implicitly_wait(10)wd.get('https://www.byhy.net/_files/stock1.html')element = wd.find_element(By.ID, 'kw')element.send_keys('通讯\n')
# import time
# time.sleep(1)# 返回页面 ID为1 的元素
element = wd.find_element(By.ID,'1')#####获取整个HTML
print(element.get_attribute('outerHTML'))

使用

print(element.get_attribute('outerHTML'))

返回结果: 

  获取整个元素内部的HTML

####获取元素内部的HTML
print(element.get_attribute('innerHTML'))

获取输入框里面的文字 

对于input输入框的元素,要获取里面的输入文本,用text属性是不行的,这时可以使用 element.get_attribute('value')。就是找到valu属性。

element = wd.find_element(By.ID, "input1")
print(element.get_attribute('value')) # 获取输入框中的文本

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/876851.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++客户端Qt开发——界面优化(QSS)

1.QSS 如果通过QSS设置的样式和通过C代码设置的样式冲突,则QSS优先级更高 ①基本语法 选择器{属性名:属性值; } 例如: QPushButton {color: red; } 1>指定控件设置样式 #include "widget.h" #include "ui_widget.h&qu…

qt--做一个拷贝文件器

一、项目要求 使用线程完善文件拷贝器的操作 主窗口不能假死主窗口进度条必须能动改写文件大小的单位(自适应) 1TB1024GB 1GB1024MB 1MB1024KB 1KB1024字节 二、所需技术 1.QFileDialog 文件对话框 QFileDialog也继承了QDialog类,直接使用静态…

Redis缓存数据库进阶——Redis与分布式锁(6)

分布式锁简介 1. 什么是分布式锁 分布式锁是一种在分布式系统环境下,通过多个节点对共享资源进行访问控制的一种同步机制。它的主要目的是防止多个节点同时操作同一份数据,从而避免数据的不一致性。 线程锁: 也被称为互斥锁(Mu…

Robot Operating System——内部审查(Introspection)Service

大纲 introspection_service检验Parameter值和类型修改内部审查(Introspection)功能的状态完整代码 introspection_client完整代码 测试参考资料 在ROS 2(Robot Operating System 2)中,内部审查(Introspect…

【中项】系统集成项目管理工程师-第7章 软硬件系统集成-7.3软件集成

前言:系统集成项目管理工程师专业,现分享一些教材知识点。觉得文章还不错的喜欢点赞收藏的同时帮忙点点关注。 软考同样是国家人社部和工信部组织的国家级考试,全称为“全国计算机与软件专业技术资格(水平)考试”&…

python 裁剪图片

情况: 有时候看视频,看到一个漂亮的妹子,按下 Alt PrintScreen 进行截图之后,会把整个屏幕都截图。 需要适当剪裁一下。 每次打开 PS , 也太慢了。 所以写个代码, 快速处理。 效果对比: 原始…

【2025留学】德国留学真的很难毕业吗?为什么大家不来德国留学?

大家好!我是德国Viviane,一句话讲自己的背景:本科211,硕士在德国读的电子信息工程。 之前网上一句热梗:“德国留学三年将是你人生五年中最难忘的七年。”确实,德国大学的宽进严出机制,延毕、休…

OOP知识整合----集合

目录 一、定义 1、集合: ( 不限制长度,存多少是多少) 2、集合框架: 二、List集合中常用的方法 1、Boolean add(Object o) 2、void add(int index,Object o) 3、Boolean remove(Object o) 4、Object remove(int index) 5、int size() 6、Boolean conta…

Code Effective学习笔记--第8章防御式编程

这一章聚焦如何通过断言和Java的异常处理机制这些防御式编程的方法来提高程序的健壮性和安全性,这是防御式编程技术的方面。但是健壮性和安全性到了一定的程度其实是矛盾的,健壮性意味着对于任何的输入,程序都不会终止而且都能给出返回&#…

Tftp服务器环境搭建

1、什么是Tftp TFTP(Trivial File Transfer Protocol,简单文件传输协议)是一种基于UDP(User Datagram Protocol)的文件传输协议,它被设计为一个非常简单的文件传输机制,特别适用于那些对复杂性有…

make2exe:自动集成测试

模板Makefile,生成多个C/C模块的集成测试程序。

免费【2024】springboot 基于微信小程序的宠物服务中心

博主介绍:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术范围:SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化…

JavaDS —— 二叉搜索树、哈希表、Map 与 Set

前言 我们将学习 Map 与 Set 这两个接口下的 TreeMap 与 TreeSet ,HashMap 与 HashSet ,在学习这四个类使用之前,我们需要先学习 二叉搜索树与 哈希表的知识。 二叉搜索树 在学习二叉树的时候,我们就已经了解过二叉搜索树的概念…

酒店智能门锁接口pro[0922]D801 对接收银-SAAS本地化-未来之窗行业应用跨平台架构

proUSB接口函数[0922中性版]-D801 调用函数库: 提供Windows下的32位动态连接库proRFL.DLL,函数使用详细说明 //-----------------------------------------------------------------------------------// 功能:读DLL版本,不涉…

【Linux C | 网络编程】进程池退出的实现详解(五)

上一篇中讲解了在进程池文件传输的过程如何实现零拷贝,具体的方法包括使用mmap,sendfile,splice等等。 【Linux C | 网络编程】进程池零拷贝传输的实现详解(四) 这篇内容主要讲解进程池如何退出。 1.进程池的简单退…

Java并发编程(上)

并发:多个线程(进程)竞争一个资源 并行:多个线程(进程)同时运行不同资源 线程和进程的关系简单地说,进程是一个容器,一个进程中可以容纳若干个线程,一个进程里面&#…

微信小程序入门

创建一个入门程序 这是index.vxml代码 <!--index.wxml--> <navigation-bar title"Weixin" back"{{false}}" color"black" background"#FFF"></navigation-bar> <view class"container" ><view&…

苹果CMS:资源采集站如何设置定时采集详细教程讲解

我们搭建好站点之后&#xff0c;会自定义一些采集&#xff0c;但是需要每天去手动执行&#xff0c;有时候甚至会忘记&#xff0c;那我们如何处理呢&#xff1f;今天我们就来介绍一下如何设置定时器。 如果按照官方例子来设置定时器会遇到一个问题就是采集的资源未绑定类型&…

WAF+API安全代表厂商|瑞数信息入选IDC报告《生成式AI推动下的中国网络安全硬件市场现状及技术发展趋势》

近日&#xff0c;全球领先的权威资讯机构IDC正式发布《IDC Market Presentation&#xff1a;生成式AI推动下的中国网络安全硬件市场现状及技术发展趋势&#xff0c;2024》报告。报告中IDC 评估了众多厂商的安全硬件产品能力&#xff0c;并给出了产品对应的推荐厂商供最终用户参…

04 | 深入浅出索引(上)

此系列文章为极客时间课程《MySQL 实战 45 讲》的学习笔记&#xff01; 索引的常见模型 可以提供查询效率的数据结构有很多&#xff0c;常见的有三种&#xff1a;哈希表、有序数组、搜索数。 哈希表是一种以 key-value 形式存储的数据结构。输入一个 key&#xff0c;通过固定…