"""
--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调用浏览器进行封装包括启用无头浏览器,及对应的浏览器配置文件的更多相关文章
-
【Python】selenium调用IE11浏览器,报错“找不到元素”NoSuchWindowException: Message:Unable to find element on closed window
当编写自动化脚本,定位浏览器元素时,报如下错误: 代码: >>> # coding=utf-8 >>> from selenium import webdriver ...
-
python之selenium调用js(execute_script)
转载: http://www.cnblogs.com/fnng/p/3230768.html 本节重点: 调用js方法 execute_script(script, *args) 在当前窗口/框架 同 ...
-
python 使用selenium模块爬取同一个url下不同页的内容(浏览器模拟人工翻页)
页面翻页,下一页可能是一个新的url 也有可能是用js进行页面跳转,url不变,解决方法是实现浏览器模拟人工翻页 目标:爬取同一个url下不同页的数据(上述第二种情况) url:http://www. ...
-
安装python的selenium库和驱动
对于使用selenium来进行python爬虫操作可以简化好多操作,它实际上的运行就是通过打开一个浏览器来一步一步的按照你的代码来执行 如果安装过python编译器后应该pip工具也是有的,验证pyt ...
-
js判断浏览器是否安装或启用了flash的方法总结
目录 # js判断浏览器是否安装或启用了flash的方法 # chrome浏览器启用flash插件的方法 # 参考 # js判断浏览器是否安装或启用了flash的方法 在传统浏览器,可以使用windo ...
-
Python+Selenium中级篇之-封装一个自己的类-浏览器引擎类
前一篇文章我们知道了,如何去封装几个简单的Selenium方法到我们自定义的类,这次我们编写一个类,叫浏览器引擎类,通过更改一个字符串的值,利用if语句去判断和控制启动那个浏览器.这里我们暂时,支持三 ...
-
【Python】 Selenium 模拟浏览器 寻路
selenium 最开始我碰到SE,是上学期期末,我们那个商务小组做田野调查时发的问卷的事情.当时在问卷星上发了个问卷,但是当时我对另外几个组员的做法颇有微词,又恰好开始学一些软件知识了,就想恶作剧( ...
-
python selenium基于显示等待封装的一些常用方法
import os import time from PIL import Image from selenium import webdriver from appium import webdri ...
-
Python 配置 selenium 模拟浏览器环境,带下载链接
使用浏览器渲染引擎.直接用浏览器在显示网页时解析HTML,应用CSS样式并执行JavaScript的语句. 这方法在爬虫过程中会打开一个浏览器,加载该网页,自动操作浏览器浏览各个网页,顺便把数据抓下来 ...
随机推荐
-
【BZOJ-1565】植物大战僵尸 拓扑排序 + 最小割
1565: [NOI2009]植物大战僵尸 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1972 Solved: 917[Submit][Statu ...
-
【.NET】传智播客第【19】期就业班视频(高清无加密)
[.NET]传智播客第[19]期就业班视频(高清无加密) 下载地址:http://fu83.cn/thread-85-1-1.html
-
如何在makefile中写cd命令
http://*.com/questions/1789594/how-to-write-cd-command-in-makefile
-
SQLSERVER 的联接查询写法
1.内连接 语法:[JOIN.INNER JOIN] 作用:两个表相连,加上ON匹配两个表的共同条件. 实例1: SELECT tb_o_i.* FROM tb_o_i INNER JOIN tb_o ...
-
java 文件操作 读取字节级数据(读取)
package com.swust; import java.io.*; /* * 功能:按照双精度浮点型.整型.布尔型.字符型.和字符串型的顺序从名为sample.dat文件读取数据 * 分析:用F ...
-
Windows下SVN服务器搭建和基本操作(服务端、客户端)
自己打算打一个SVN服务器了解一下,所以顺便记录一下整个的过程 下载 服务端 https://www.visualsvn.com/server/download/ 客户端 https://www.vi ...
-
MYSQL性能优化(3)
优化数据库对象 1.优化表的数据类型 select * from tbl1 procedure analyse(16,256) ,会输出优化建议,结合情况优化 2.拆分表(仅Myisam) 2.1 纵 ...
-
C# CEF 封装UserControl
using System; using System.Collections.Generic; using System.ComponentModel; using System.Drawing; u ...
-
Tree-669. Trim a Binary Search Tree
Given a binary search tree and the lowest and highest boundaries as L and R, trim the tree so that a ...
-
RK3288 增加双屏异显 eDP+LVDS
CPU:RK3288 系统:Android 5.1 下面是官方文档中的信息. 1.rk3288 支持的显示接口可以任意组合. 2.双屏异显时,一个显示接口当主屏,另一个当副屏:主副屏由板级 dts 文 ...