"""

--base.py

基类封装

Selenium 封装基类

封装查找元素以及集成日志输出

"""

from HTMLReport import logger

from selenium import webdriver

from selenium.webdriver.remote.webelement import WebElement

class Base(object):

def __init__(self, driver: webdriver.Remote = None):
self.driver = driver
self.logger = logger() def find_element(self, locator: tuple) -> WebElement:
"""查找单个元素 :param locator: 定位器(by=By.ID, value=None)
:return: WebElement
"""
self.logger.info(f"查找元素:{locator}")
try:
element = self.driver.find_element(*locator)
except Exception:
self.logger.info("查找元素失败")
raise
else:
self.logger.info("查找元素成功")
return element def find_elements(self, locator: tuple):
"""查找元素集合 :param locator: 定位器(by=By.ID, value=None)
:return: 元素对象集合
:rtype: list of WebElement
"""
self.logger.info(f"查找元素集合:{locator}")
elements = self.driver.find_elements(*locator)
self.logger.info(f"查找到{len(elements)}个元素")
return elements

"""

获取浏览器

打开本地浏览器

打开远程浏览器

关闭浏览器

打开网址

最大化

最小化

标题

url

刷新

Python对Selenium封装浏览器调用

------browser.py文件

"""

from selenium import webdriver

from Common.tools.rw_ini import read_config
from .base import Base class Browser(Base):
def get_web_driver(self) -> webdriver.Remote:
"""获取浏览器实例 :return: 浏览器实例
"""
rc = read_config("browser.ini")
local_browser = rc.getboolean("local", "local_browser", fallback=True)
wait_time = rc.getint("local", "wait_time", fallback=10) browser_name = rc.get("browser", "name", fallback="chrome")
window_width = rc.get("browser", "window_width", fallback=None)
window_height = rc.get("browser", "window_height", fallback=None) command_executor = rc.get("grid", "command_executor", fallback="http://127.0.0.1:4444/wd/hub")
headless = rc.getboolean("grid", "headless", fallback=False)
proxy = rc.get("grid", "proxy", fallback=None) if local_browser:
# 打开本地浏览器
driver = self._get_local_web_driver(browser_name)
else:
# 打开远程浏览器
driver = self._get_remote_web_driver(browser_name, command_executor, headless, proxy)
self.logger.info(f"打开浏览器:{driver.name}") self.logger.info(f"设置隐式等待:{wait_time}s")
driver.implicitly_wait(wait_time) if window_width is None or window_width == "" or window_height is None or window_height == "":
self.logger.info("最大化浏览器")
driver.maximize_window()
else:
driver.set_window_size(window_width, window_height)
return driver def _get_local_web_driver(self, browser_name: str) -> webdriver.Remote:
"""获取本地浏览器实例 :param browser_name: 浏览器类型
:return: 浏览器实例
"""
if browser_name.upper() == "CHROME":
driver = webdriver.Chrome()
elif browser_name.upper() == "FIREFOX":
driver = webdriver.Firefox()
elif browser_name.upper() == "IE":
driver = webdriver.Ie()
else:
self.logger.error(f"浏览器类型错误:{browser_name}")
raise ValueError(f"浏览器类型错误:{browser_name}")
return driver def _get_remote_web_driver(self, browser_name, command_executor, headless, proxy) -> webdriver.Remote:
"""获取远程浏览器实例 :param browser_name: 浏览器类型
:param command_executor: HUB 地址
:param headless: 使用无头浏览器
:param proxy: 代理
:return: 浏览器实例
"""
if browser_name.upper() == "CHROME":
options = webdriver.ChromeOptions()
elif browser_name.upper() == "FIREFOX":
options = webdriver.FirefoxOptions()
elif browser_name.upper() == "IE":
options = webdriver.IeOptions()
else:
self.logger.error(f"浏览器类型错误:{browser_name}")
raise ValueError(f"浏览器类型错误:{browser_name}") if proxy is not None:
options.add_argument(f"--proxy-server={proxy}")
# 无头浏览器
options.headless = headless driver = webdriver.Remote(
command_executor=command_executor,
options=options
)
return driver def quit(self):
"""退出浏览器"""
self.logger.info(f"关闭浏览器:{self.driver.name}")
self.driver.quit() def get(self, url: str, new: bool = False):
"""打开 url :param url: 网址
:param new: 是否新窗口打开
:return: None
"""
if new:
self.logger.info(f"新窗口打开 url:{url}")
self.driver.execute_script(f"window.open('{url}')")
else:
self.logger.info(f"当前窗口打开 url:{url}")
self.driver.get(url) def get_session_id(self):
"""返回当前浏览器 session id"""
session_id = self.driver.session_id
self.logger.info(f"当前浏览器 session_id:{session_id}")
return session_id def get_source(self) -> str:
"""获取当前页面HTML源代码"""
page_source = self.driver.page_source
self.logger.info(f"当前页面源代码:\n{page_source}")
return page_source def get_title(self):
"""返回当前页面的标题"""
title = self.driver.title
self.logger.info(f"当前页面的标题:{title}")
return title def get_current_url(self):
"""返回当前页面的URL"""
current_url = self.driver.current_url
self.logger.info(f"当前页面URL:{current_url}")
return current_url def reload_page(self):
"""模拟用户重新加载页面"""
self.logger.info("刷新页面")
self.driver.refresh()

浏览器配置文件:

------browser.ini文件

[local]
local_browser = False
wait_time = 10 [browser]
name = chrome
;name = firefox
;name = ie
window_width =
window_height = [grid]
command_executor = http://127.0.0.1:4444/wd/hub
headless = False
proxy =

rw_ini.py读取配置文件请查看下面链接:

https://www.cnblogs.com/CesareZhang/p/10738541.html

Python对Selenium调用浏览器进行封装包括启用无头浏览器,及对应的浏览器配置文件的更多相关文章

  1. 【Python】selenium调用IE11浏览器,报错“找不到元素”NoSuchWindowException: Message:Unable to find element on closed window

    当编写自动化脚本,定位浏览器元素时,报如下错误: 代码: >>> # coding=utf-8 >>> from selenium import webdriver ...

  2. python之selenium调用js(execute_script)

    转载: http://www.cnblogs.com/fnng/p/3230768.html 本节重点: 调用js方法 execute_script(script, *args) 在当前窗口/框架 同 ...

  3. python 使用selenium模块爬取同一个url下不同页的内容(浏览器模拟人工翻页)

    页面翻页,下一页可能是一个新的url 也有可能是用js进行页面跳转,url不变,解决方法是实现浏览器模拟人工翻页 目标:爬取同一个url下不同页的数据(上述第二种情况) url:http://www. ...

  4. 安装python的selenium库和驱动

    对于使用selenium来进行python爬虫操作可以简化好多操作,它实际上的运行就是通过打开一个浏览器来一步一步的按照你的代码来执行 如果安装过python编译器后应该pip工具也是有的,验证pyt ...

  5. js判断浏览器是否安装或启用了flash的方法总结

    目录 # js判断浏览器是否安装或启用了flash的方法 # chrome浏览器启用flash插件的方法 # 参考 # js判断浏览器是否安装或启用了flash的方法 在传统浏览器,可以使用windo ...

  6. Python+Selenium中级篇之-封装一个自己的类-浏览器引擎类

    前一篇文章我们知道了,如何去封装几个简单的Selenium方法到我们自定义的类,这次我们编写一个类,叫浏览器引擎类,通过更改一个字符串的值,利用if语句去判断和控制启动那个浏览器.这里我们暂时,支持三 ...

  7. 【Python】 Selenium 模拟浏览器 寻路

    selenium 最开始我碰到SE,是上学期期末,我们那个商务小组做田野调查时发的问卷的事情.当时在问卷星上发了个问卷,但是当时我对另外几个组员的做法颇有微词,又恰好开始学一些软件知识了,就想恶作剧( ...

  8. python selenium基于显示等待封装的一些常用方法

    import os import time from PIL import Image from selenium import webdriver from appium import webdri ...

  9. Python 配置 selenium 模拟浏览器环境,带下载链接

    使用浏览器渲染引擎.直接用浏览器在显示网页时解析HTML,应用CSS样式并执行JavaScript的语句. 这方法在爬虫过程中会打开一个浏览器,加载该网页,自动操作浏览器浏览各个网页,顺便把数据抓下来 ...

随机推荐

  1. 转:SQL中 patindex函数的用法

    语法格式:PATINDEX ( '%pattern%' , expression ) 返回pattern字符串在表达式expression里第一次出现的位置,起始值从1开始算. pattern字符串在 ...

  2. HTTP的cookie

    HTTP cookies,通常又称作"cookies",已经存在了很长时间,但是仍旧没有被予以充分的理解.首要的问题是存在了诸多误区,认为cookies是后门程序或病毒,或压根不知 ...

  3. JDOM 操作XML

    http://www.cnblogs.com/hoojo/archive/2011/08/11/2134638.html 可扩展标记语言——eXtensible Markup Language 用户可 ...

  4. Mojave使用pyenv安装python-zlib错误

    mojave使用pyenv编译python出现 zipimport.ZipImportError: can't decompress data; zlib not available错误 解决方案: ...

  5. Django商城项目笔记No.12用户部分-QQ登录2获取QQ用户openid

    Django商城项目笔记No.12用户部分-QQ登录2获取QQ用户openid 上一步获取QQ登录网址之后,测试登录之后本该跳转到这个界面 但是报错了: 新建oauth_callback.html & ...

  6. 一篇关于介绍php的几个user 认证相关的几个包

    http://kodeinfo.com/post/laravel-authentication-packages LARAVEL AUTHENTICATION PACKAGES By Imran Iq ...

  7. python第二十九课——文件读写(读取读取中文字符)

    演示:读取中文字符 结论: 1).如果不设置encoding,默认使用gbk进行编解码 2).如果编码和解码不一致,最终导致报错,但是一旦设置了errors='ingore',那么就不会报错,而采取乱 ...

  8. 关于ARMv8指令的几个问题

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/qianlong4526888/article/details/27512629 NOTE:下面内容仅 ...

  9. BZOJ4556:[TJOI\HEOI2016]字符串(后缀数组,主席树,二分,ST表)

    Description 佳媛姐姐过生日的时候,她的小伙伴从某东上买了一个生日礼物.生日礼物放在一个神奇的箱子中.箱子外边写了一个长为n的字符串s,和m个问题.佳媛姐姐必须正确回答这m个问题,才能打开箱 ...

  10. Effective MySQL之SQL语句最优化——读书笔记之一

    第一章,DBA5分钟速成 本章知识点如下: 寻找运行慢SQL的语句: show full processlist查看所有正在执行的进程及执行的语句耗时: 命令后面\G可以让命令按行显示(默认是按列). ...