自动点击网页脚本---selenium库使用

selenium操作各种浏览器

下载浏览器对应版本的chromedriver.exe放到 %systemroot%目录或其它可以被系统环境找到的目录下

#coding:utf-8

from selenium import webdriver

from selenium.webdriver.chrome.options import Options

import time

#配置360浏览器地址开始

__browser_url = r'D:\Program Files\360Chrome\Chrome\Application\360chrome.exe' #浏览器目录地址

chrome_driver = "C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe"

chrome_options = Options()

chrome_options.binary_location = __browser_url

#配置360浏览器地址结束

brower = webdriver.Chrome(chrome_driver,options=chrome_options)

#brower = webdriver.Firefox()

#brower = webdriver.IE()

brower.find_elements_by_......

浏览器启用方式

启动Chrome浏览器:

from selenium import webdriver

browser = webdriver.Chrome()

browser.get('https://www.lidihuo.com/')

启动Firefox浏览器:

from selenium import webdriver

browser = webdriver.Firefox()

browser.get('https://www.lidihuo.com/')

启动IE浏览器:

from selenium import webdriver

browser = webdriver.Ie()

browser.get('https://www.lidihuo.com/')

添加浏览器参数add_argument

chrome_options.add_argument('--参数1 --参数2')

chrome_options.add_experimental_option('excludeSwitches', ['enable-logging']) #不输出console.log的日志内容到控制台

chrome_options.add_argument('--start-maximized')              # 最大化运行(全屏窗口),不设置,取元素会报错

chrome_options.add_experimental_option('excludeSwitches', ['enable-automation']) #规避部分网站对selenium的检测

browser = webdriver.Chrome(options=chrome_options) #加载参数

具体可参见 https://peter.sh/experiments/chromium-command-line-switches/ ,该网站罗列了所有的参数。

设置代理

chrome_options.add_argument('--proxy-server=http://{ip}:{port}')

Headless方式启动

Headless Chrome 是 Chrome 浏览器的无界面形态,可以在不打开浏览器的前提下,使用所有 Chrome 支持的特性运行你的程序。相比于现代浏览器,Headless Chrome 更加方便测试 web 应用,获得网站的截图,做爬虫抓取信息等。相比于较早的 PhantomJS,SlimerJS 等,Headless Chrome 则更加贴近浏览器环境。

Headless Chrome 对Chrome版本要求:

官方文档中介绍,mac和linux环境要求chrome版本是59+,而windows版本的chrome要求是60+,同时chromedriver要求2.30+版本。

from selenium import webdriver

chrome_options = webdriver.ChromeOptions()

# 使用headless无界面浏览器模式

chrome_options.add_argument('--headless')

chrome_options.add_argument('--disable-gpu')

# 启动浏览器,获取网页源代码

browser = webdriver.Chrome(options=chrome_options)

加载配置启动浏览器

Selenium操作浏览器是不加载任何配置的,下面是关于加载Chrome配置的方法:

用Chrome地址栏输入chrome://version/,查看自己的“个人资料路径”,然后在浏览器启动时,调用这个配置文件,代码如下:

# coding=utf-8

from selenium import webdriver

option = webdriver.ChromeOptions()

# 设置成用户自己的数据目录

option.add_argument('--user-data-dir=C:\Users\Administrator\AppData\Local\Google\Chrome\User Data')

driver=webdriver.Chrome(options=option)

单独配置浏览器selenium驱动位置

chrome_driver = "C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe"

driver = webdriver.Chrome(chrome_driver, chrome_options=chrome_options)

而加载Firefox配置的方法有些不同:

打开Firefox点右上角设置>?(帮助)>故障排除信息>显示文件夹,打开后把路径复制下来就可以了

# coding=utf-8

from selenium import webdriver

# 配置文件地址

profile_directory = r'C:\Users\xxx\AppData\Roaming\Mozilla\Firefox\Profiles\1x41j9of.default'

# 加载配置配置

profile = webdriver.FirefoxProfile(profile_directory)

# 启动浏览器配置

driver = webdriver.Firefox(profile)

使用selenium控制已打开的浏览器

这里给出Google Chrome浏览器的解决方案。

我们可以利用Chrome DevTools协议。它允许客户检查和调试Chrome浏览器。

打开cmd,在命令行中输入命令:

chrome.exe --remote-debugging-port=9222 --user-data-dir="C:\selenum\AutomationProfile"

对于-remote-debugging-port值,可以指定任何打开的端口。

对于-user-data-dir标记,指定创建新Chrome配置文件的目录。它是为了确保在单独的配置文件中启动chrome,不会污染你的默认配置文件。

还有,不要忘了在环境变量中PATH里将chrome的路径添加进去。

此时会打开一个浏览器页面,我们输入百度网址,我们把它当成一个已存在的浏览器:

from selenium import webdriver

from selenium.webdriver.chrome.options import Options



chrome_options = Options()

chrome_options.add_experimental_option("debuggerAddress", "127.0.0.1:9222")

chrome_driver = "C:\Program Files (x86)\Google\Chrome\Application\chromedriver.exe"

driver = webdriver.Chrome(chrome_driver, chrome_options=chrome_options)

print(driver.title)

会发现打印出了 “百度一下,你就知道” 的网页标题。这样我们就实现了对一个已打开的浏览器的控制。

webdriver.chrome()

其它

execute_script('js代码')

需要先新建js代码,再执行

js='scrollTo(0,1000)' js滚动代码

switch_to_alert()

quit() 退出浏览器

元素定位

查找一个元素

find_element_by_id()

find_element_by_name()

find_element_by_link_text() 匹配全部文本

find_element_by_partial_link_text() 部分文本匹配

find_element_by_xpath()

find_element_by_class_name() 单类名用

find_element_by_tag_name()

find_element_by_css_selector() css通用

查找一组元素

find_elements_by_id()

find_elements_by_name()

find_elements_by_link_text()

find_elements_by_partial_link_text()

find_elements_by_xpath()

find_elements_by_class_name()

find_elements_by_tag_name()

find_elements_by_css_selector()

class含有空格时解决方法

直接包含空格的CSS属性定位大法

find_element_by_css_selector("[class='classname1 classname2']").send_keys("yoyo")

或者在每个class前面加上点

find_element_by_css_selector('.dtb-style-1.table-dragColumns').click()

元素操作方法

send_keys() 发送文本或按键

发送回车键

要想调用键盘按键操作需要引入 keys 包:

from selenium.webdriver.common.keys import Keys

通过 send_keys()调用按键:

send_keys(Keys.ENTER)

键盘组合键的用法:

# ctrl+a 全选输入框内容

send_keys(Keys.CONTROL,'a')

发送文本

send_keys("你好吗")

click() 单击

clear() 清除对象内容

submit() 提交

text() 获取元素文本信息

获取元素属性和文本

get_attribute()

innerHTML:会返回元素的内部 HTML, 包含所有的HTML标签。

textContent:获取 HTML 文本,需要注意的是 textContent 是 W3C 兼容的文字内容属性,不支持 IE 浏览器。

innerText:获取 HTML 文本,与 textContent 不同的是 innerText 不是 W3C DOM 的指定内容,不支持 FireFox 浏览器。

value:获取带有 value 属性的值。

get_property()

浏览器操作

将浏览器最大化显示

browser.maximize_window()

将浏览器最小化显示

browser.minimize_window()

浏览器设置窗口大小

设置浏览器宽480、高800显示

browser.set_window_size(480, 800)

浏览器前进后退

前进

browser.forword()

后退

browser.back()

三种等待方式

强制等待

time.sleep(秒)

需要导入time包

隐性等待

通过添加 implicitly_wait() 方法就可以方便的实现智能等待;等待隐形等待是设置了一个最长等待时间,如果在规定时间内网页加载完成,则执行下一步,否则一直等到时间截止,然后执行下一步。

implicitly_wait(30) 智能等待30秒

隐性等待对整个driver的周期都起作用,所以只要设置一次即可

显性等待

WebDriverWait(driver, 超时时长, 调用频率, 忽略异常).until(可执行方法, 超时时返回的信息)

init

until

until_not

多层框架定位

switch_to_frame

Xpath&Css定位方法速查表

描述 Xpath Css

直接子元素 //div/a div > a

子元素或后代元素 //div//a div a

以id定位 //div[@id='idValue']//a div#idValue a

以class定位 //div[@class='classValue']//a div.classValue a

同级弟弟元素 //ul/li[@class='first']/following- ul>li.first + li

属性 //form/input[@name='username'] form input[name='username']

多个属性 //input[@name='continue' and input[name='continue'][type='button

第4个子元素 //ul[@id='list']/li[4] ul#list li:nth-child(4)

第1个子元素 //ul[@id='list']/li[1] ul#list li:first-child

最后1个子元素 //ul[@id='list']/li[last()] ul#list li:last-child

属性包含某字段 //div[contains(@title,'Title')] div[title*="Title"]

属性以某字段开头 //input[starts-with(@name,'user')] input[name^="user"]

属性以某字段结尾 //input[ends-with(@name,'name')] input[name$="name"]

text中包含某字段 //div[contains(text(), 'text')] 无法定位

元素有某属性 //div[@title] div[title]

父节点 //div/.. 无法定位

同级哥哥节点 //li/preceding-sibling::div[1] 无法定位

Python Webdriver Exception速查表

webdriver在使用过程中可能会出现各种异常,我们需要了解该异常并知道如何进行异常处理。

异常 描述

WebDriverException 所有webdriver异常的基类,当有异常且不属于下列异常时抛出

InvalidSwitchToTargetException 下面两个异常的父类,当要switch的目标不存在时抛出

NoSuchFrameException 当你想要用switch_to.frame()切入某个不存在的frame时抛出

NoSuchWindowException 当你想要用switch_to.window()切入某个不存在的window时抛出

NoSuchElementException 元素不存在,一般由find_element与find_elements抛出

NoSuchAttributeException 一般你获取不存在的元素属性时抛出,要注意有些属性在不同浏览器里是有不同的属性名的

StaleElementReferenceException 指定的元素过时了,不在现在的DOM树里了,可能是被删除了或者是页面或iframe刷新了

UnexpectedAlertPresentException 出现了意料之外的alert,阻碍了指令的执行时抛出

NoAlertPresentException 你想要获取alert,但实际没有alert出现时抛出

InvalidElementStateException 下面两个异常的父类,当元素状态不能进行想要的操作时抛出

ElementNotVisibleException 元素存在,但是不可见,不可以与之交互

ElementNotSelectableException 当你想要选择一个不可被选择的元素时抛出

InvalidSelectorException 一般当你xpath语法错误的时候抛出这个错

InvalidCookieDomainException 当你想要在非当前url的域里添加cookie时抛出

UnableToSetCookieException 当driver无法添加一个cookie时抛出

TimeoutException 当一个指令在足够的时间内没有完成时抛出

MoveTargetOutOfBoundsException actions的move操作时抛出,将目标移动出了window之外

UnexpectedTagNameException 获取到的元素标签不符合要求时抛出,比如实例化Select,你传入了非select标签的元素时

ImeNotAvailableException 输入法不支持的时候抛出,这里两个异常不常见,ime引擎据说是仅用于linux下对中文/日文支持的时候

ImeActivationFailedException 激活输入法失败时抛出

ErrorInResponseException 不常见,server端出错时可能会抛

RemoteDriverServerException 不常见,好像是在某些情况下驱动启动浏览器失败的时候会报这个错

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值