接着上篇随笔 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的二次封装(十)的更多相关文章

  1. 《手把手教你》系列基础篇(九十七)-java+ selenium自动化测试-框架设计篇-Selenium方法的二次封装和页面基类(详解教程)

    1.简介 上一篇宏哥介绍了如何设计支持不同浏览器测试,宏哥的方法就是通过来切换配置文件设置的浏览器名称的值,来确定启动什么浏览器进行脚本测试.宏哥将这个叫做浏览器引擎类.这个类负责获取浏览器类型和启动 ...

  2. selenium + python自动化测试unittest框架学习(五)webdriver的二次封装

    因为webdriver的api方法很长,再加上大多数的定位方式是以xpath方式定位,更加让代码看起来超级长,为了使整体的代码看起来整洁,对webdriver进行封装,学习资料来源于虫师的<se ...

  3. webdriver+expected_conditions二次封装

    结合这两种方法对代码做二次封装,可以提升脚本性能 例: #coding:utf-8 #封装元素方法from selenium import webdriverfrom selenium.webdriv ...

  4. 自动化测试框架中关于selenium api的二次封装

    不多说,直接看代码如下: #coding:utf-8 from selenium import webdriver from selenium.webdriver.common.action_chai ...

  5. python mysql redis mongodb selneium requests二次封装为什么大都是使用类的原因,一点见解

    1.python mysql  redis mongodb selneium requests举得这5个库里面的主要被用户使用的东西全都是面向对象的,包括requests.get函数是里面每次都是实例 ...

  6. python+selenium十:selenium的二次封装

    python+selenium十:基于原生selenium的二次封装   from selenium import webdriverfrom selenium.webdriver.support.w ...

  7. python+selenium十:基于原生selenium的二次封装

    from selenium import webdriverfrom selenium.webdriver.support.wait import WebDriverWaitfrom selenium ...

  8. Python3 Selenium自动化web测试 ==> 第十一节 WebDriver高级应用 -- 显示等待 + 二次封装

    学习目的: 掌握显示等待 掌握二次封装 正式步骤: step1:显示等待的代码示例 # -*- coding:utf-8 -*- from selenium import webdriver from ...

  9. Python_selenium二次封装selenium的几个方法

    Python_selenium二次封装selenium的几个方法 将常用的几个webdriver方法封装到自己写的一个类中去,此实例中是将"浏览器后退.浏览器前进.打开站点和关闭浏览器&qu ...

随机推荐

  1. C#程序代码中常用的快捷键

    C#中的快捷键,可以更方便的编写代码 //CTRL + SHIFT + B 生成解决方案 //CTRL + F7 生成编译 //CTRL + O 打开文件 //CTRL + SHIFT + O 打开项 ...

  2. Visual Studio 2019 发布活动 - 2019 年 4 月 2 日

    Visual Studio 2019 发布活动 2019 年 4 月 2 日,星期二 | 上午 9:00 (PT) 围观: https://visualstudio.microsoft.com/zh- ...

  3. C# 获取系统当前IE版本号

    1. 注册表中,IE的位置: 计算机\HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432Node\Microsoft\Internet Explorer 2. 通过注册表读取IE配 ...

  4. 关于thinkphp5手动抛出Http异常时自定义404页面报错的问题

    在使用HttpException手动抛出异常时,希望跳转到自定义的错误页面,官方的文章中是这样描述的. 可以使用\think\exception\HttpException类来抛出异常 // 抛出 H ...

  5. 配置IIS网站,我遇到的那些坑~

    配置错误 不能在此路径中使用此配置节.如果在父级别上锁定了该节,便会出现这种情况.锁定是默认设置的(overrideModeDefault="Deny"),或者是通过包含 over ...

  6. Cocos Creator 资源加载流程剖析【一】——cc.loader与加载管线

    这系列文章会对Cocos Creator的资源加载和管理进行深入的剖析.主要包含以下内容: cc.loader与加载管线 Download部分 Load部分 额外流程(MD5 Pipe) 从编辑器到运 ...

  7. mysql性能优化之数据库级别优化--优化sql语句

    一  优化SELECT语句 1.1 WHERE子句优化 本文暂时只讨论可以处理WHERE子句的优化,下面的一些实例使用SELECT语句,但是相同的优化同样适用DELETE和UPDATE语句中的WHER ...

  8. 安卓 App 性能专项测试指标之 CPU 深度解析

    指标背景 很多场景下我们去使用App,可能会碰到手机会出现发热发烫的现象.这是因为CPU使用率过高.CPU过于繁忙,会使得整个系统无法响应用户,整体性能降低,用户体验变得相当差,也容易引起ANR等等一 ...

  9. Tomcat的测试网页换成自己项目首页

    <Host name="localhost" appBase="webapps" unpackWARs="true" autoDepl ...

  10. 阿里ECS配置MSSQL远程连接的坑

    mssql 2012 r2远程配置的相关文档有太多: 如:sql server2012 远程访问设置 这里不做远程配置的设置介绍.这篇随笔存在的意义在于,你除了要设置服务器,还需要到阿里云控制台设置安 ...