selenium-webdriver的二次封装(十)
接着上篇随笔 selenium-配置文件定位元素 ,进行了配置文件设置后,将配置文件运用到定位元素中
思路:拿到定位的 key 和 value 后,对 webdrvier 中定位进行封装,使可以直接运用
主要的8种定位方法:
- find_element_by_id
- find_element_by_name
- find_element_by_xpath
- find_element_by_link_text
- find_element_by_partial_link_text
- find_element_by_tag_name
- find_element_by_class_name
- find_element_by_css_selector
# conding=utf-8 from selenium import webdriver
from auto_learning.config import ReadIni #导入读取的配置文件的py文件,如果不能导入检查是否是包(__init__.py文件存在 )文件 class FindElement(object):
def __init__(self,driver):
self.driver = driver def get_Element(self,pageElement,key):
# 实例化ReadIni
file_name = '../config/BaiduElement.ini'
read_ini = ReadIni.ReadIni(file_name)
key_value = read_ini.get_value(pageElement,key)
key = key_value.split(':')[0]
value = key_value.split(':')[1] try:
if key == 'id':
return self.driver.find_element_by_id(value)
elif key == 'class':
return self.driver.find_element_by_class_name(value)
elif key == 'name':
return self.driver.find_element_by_name(value)
elif key == 'tag':
return self.driver.find_element_by_tag_name(value)
elif key == 'linkText':
return self.driver.find_element_by_link_text(value)
elif key == 'cssSelector':
return self.driver.find_element_by_css_selector(value)
elif key == 'xpath':
return self.driver.find_element_by_xpath(value) except:
return None
由于浏览器有好多种,所以也需要重新定义浏览器的启动
对构造函数进行修改
def __init__(self,driverName):
try:
if driverName == 'chrome':
self.driver = webdriver.Chrome()
elif driverName == 'dege':
self.driver = webdriver.Edge()
elif driverName == 'firefox':
self.driver = webdriver.Firefox()
elif driverName == 'safari':
self.driver = webdriver.Safari() except:
error_message = "find not " + driverName
print(error_message) self.driver.maximize_window()
url = 'https://www.baidu.com'
self.driver.get(url)
在项目中如果用单一浏览器可能会造成堵塞
所以就需要多个浏览器同时跑脚本,不至于一个浏览器的压力太大
# conding=utf-8 from selenium import webdriver
import time
from auto_learning.config import ReadIni #导入读取的配置文件的py文件,如果不能导入检查是否是包(__init__.py文件存在 )文件 class FindElement(object):
def __init__(self,i):
self.driver = self.get_driver(i)
time.sleep(3)
url = 'https://www.baidu.com'
self.driver.get(url)
self.driver.maximize_window() def get_driver(self,i):
if i == 0:
return webdriver.Chrome()
elif i == 1:
return webdriver.Edge()
elif i == 2:
return webdriver.Firefox()
elif i == 3:
return webdriver.Safari() def get_Element(self,pageElement,key):
# 实例化ReadIni
file_name = '../config/BaiduElement.ini'
read_ini = ReadIni.ReadIni(file_name)
key_value = read_ini.get_value(pageElement,key)
key = key_value.split(':')[0]
value = key_value.split(':')[1] try:
if key == 'id':
return self.driver.find_element_by_id(value)
elif key == 'class':
return self.driver.find_element_by_class_name(value)
elif key == 'name':
return self.driver.find_element_by_name(value)
elif key == 'tag':
return self.driver.find_element_by_tag_name(value)
elif key == 'linkText':
return self.driver.find_element_by_link_text(value)
elif key == 'cssSelector':
return self.driver.find_element_by_css_selector(value)
elif key == 'xpath':
return self.driver.find_element_by_xpath(value) except:
return None if __name__ == '__main__':
for i in range(3):
findElement = FindElement(i)
input_text = findElement.get_Element('BaiduHomeElement','baidu_search_input')
selenium-webdriver的二次封装(十)的更多相关文章
- 《手把手教你》系列基础篇(九十七)-java+ selenium自动化测试-框架设计篇-Selenium方法的二次封装和页面基类(详解教程)
1.简介 上一篇宏哥介绍了如何设计支持不同浏览器测试,宏哥的方法就是通过来切换配置文件设置的浏览器名称的值,来确定启动什么浏览器进行脚本测试.宏哥将这个叫做浏览器引擎类.这个类负责获取浏览器类型和启动 ...
- selenium + python自动化测试unittest框架学习(五)webdriver的二次封装
因为webdriver的api方法很长,再加上大多数的定位方式是以xpath方式定位,更加让代码看起来超级长,为了使整体的代码看起来整洁,对webdriver进行封装,学习资料来源于虫师的<se ...
- webdriver+expected_conditions二次封装
结合这两种方法对代码做二次封装,可以提升脚本性能 例: #coding:utf-8 #封装元素方法from selenium import webdriverfrom selenium.webdriv ...
- 自动化测试框架中关于selenium api的二次封装
不多说,直接看代码如下: #coding:utf-8 from selenium import webdriver from selenium.webdriver.common.action_chai ...
- python mysql redis mongodb selneium requests二次封装为什么大都是使用类的原因,一点见解
1.python mysql redis mongodb selneium requests举得这5个库里面的主要被用户使用的东西全都是面向对象的,包括requests.get函数是里面每次都是实例 ...
- python+selenium十:selenium的二次封装
python+selenium十:基于原生selenium的二次封装 from selenium import webdriverfrom selenium.webdriver.support.w ...
- python+selenium十:基于原生selenium的二次封装
from selenium import webdriverfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium ...
- Python3 Selenium自动化web测试 ==> 第十一节 WebDriver高级应用 -- 显示等待 + 二次封装
学习目的: 掌握显示等待 掌握二次封装 正式步骤: step1:显示等待的代码示例 # -*- coding:utf-8 -*- from selenium import webdriver from ...
- Python_selenium二次封装selenium的几个方法
Python_selenium二次封装selenium的几个方法 将常用的几个webdriver方法封装到自己写的一个类中去,此实例中是将"浏览器后退.浏览器前进.打开站点和关闭浏览器&qu ...
随机推荐
- 将个人博客从GitHub迁移至阿里云服务器过程总结
让我们先回顾下前两篇博客: 程序员如何从0到1搭建自己的技术博客 在个人博客中优雅的使用Gitalk评论插件 通过前两篇博客,我们了解了如何快速的从0到1搭建一个个人博客并使用了Gitalk评论插件, ...
- Nginx 一个高性能的HTTP和反向代理服务器
本文只针对Nginx在不加载第三方模块的情况能处理哪些事情,由于第三方模块太多所以也介绍不完,当然本文本身也可能介绍的不完整,毕竟只是我个人使用过和了解过,欢迎留言交流. Nginx能做什么 ——反向 ...
- Windows Server 2016-活动目录NTP时间同步
在实际生产域环境下,往往会有很多跟时间不同步相关的问题,简单的说几种常见的情景:本地客户端时间与域控时间不统一导致无法加域:每次客户端电脑输入密码到进入桌面环境等N久:Skype for Busine ...
- REST API disable / enable service auto start by API
how to disable service auto start by API as the following how to enable service auto start by API as ...
- css+js调整当前界面背景音量
展示效果 html代码: <div> <audio id="audio" controls src="https://dbl.5518pay.com/r ...
- 一道编程题: 在1~n之间选择若干个数,使其和为m
这是一道很明显的动态规划的题目. 递推公式为 用sum(n, m)表示所有可能的1~n之间存在的和为m的组合 那么 sum(n,m) = sum(n-1, m) | sum(n-1, m-n) 直接上 ...
- 解决ASP.NET Core MVC调试慢的问题
最近在做的一个项目中,发现网页端同时发起了4个AJAX请求需要数秒才获取到响应,太慢了,当我把请求数降低为1个的时候,速度看起来就比较正常,增加到2个同时的请求后,速度就有些慢了,3个的话就明显慢了, ...
- MySQL 查询重复数据,删除重复数据保留id最小的一条作为唯一数据
开发背景: 最近在做一个批量数据导入到MySQL数据库的功能,从批量导入就可以知道,这样的数据在插入数据库之前是不会进行重复判断的,因此只有在全部数据导入进去以后在执行一条语句进行删除,保证数据唯一性 ...
- JavaFX技术简要总结
最近,做一个桌面应用程序的项目,需要考察相关技术,对于经常使用Java的我们来说,很自然的找Java的桌面程序开发技术,发现JavaFX是比较合适的,简单熟悉了一下,写出来给大家做个参考. 一 Jav ...
- 配置中心框架IConfCenter
本篇和大家分享的是一个简易配置中心框架IConfCenter,框架是利用空余时间写的,主要以配置文件+redis存储方式作为数据同步驱动,目前支持的配置文件格式有 .properties 和 .con ...