python+selenium自动化(三)

6 篇文章 0 订阅
3 篇文章 0 订阅

from selenium.webdriver.common.action_chains import ActionChains

#鼠标悬停在搜索设置按钮上

mouse=driver.find_element_by_link_text("设置")

ActionChains(driver).move_to_element(mouse).perform()

右击鼠标  context_click()

双击鼠标  double_click()

获取当前页面的句柄:driver.current_window_handle

driver.implicitly_wait(10)   隐藏等待

获取所有句柄:driver.window_handles

切换句柄:driver.switch_to.window(i)

import random

设置随机值范围为0~9:a=random.randint(0~9)

iframe标记又叫浮动帧标记

切换iframe:driver.switch_to_frame("x-URS-iframe")

推荐:driver.switch_to.frame()

释放iframe,重新回到主页面上

driver.switch_to.default_content()

#下拉框

driver.find_element_by_id("nr").find_element_by_xpath("//option[@value='50']").click()

driver.find_element_by_xpath("./*[@id='nr']/option[2]").click()

from selenium.webdriver.support.select import Select

s=driver.find_element_by_id("nr")

Select(s).select_by_index(2)

Select(s).select_by_value("20")

Select(s).select_by_visible_text("每页显示50条")

select_by_index() :通过索引定位

select_by_value() :通过 value 值定位

select_by_visible_text() :通过文本值定位

deselect_all()           取消所有选项
deselect_by_index()  取消对应index选项
deselect_by_value()   取消对应value选项

deselect_by_visible_text() :取消对应文本选项

first_selected_option() :返回第一个选项

all_selected_options() :返回所有的选项

alert\confirm\prompt弹出框操作主要方法有:

text 获取文本值

accept()   点击确认

dismiss() 点击取消或者叉掉对话框

send_keys() 输入文本值--仅限于prompt,在alert和confirm上没有输入框

switch_to_alert()方法切换到alert弹出框上

可以用text方法获取弹出的文本信息

accept()点击确认按钮

dismiss()相当于点右上角x,取消弹出框

send_keys()这里多个输入框,可以用 send_keys()方法输入文本内容

# 点击后,判断元素是否为选中状态
r = driver.find_element_by_id("boy").is_selected()

由于文件路径存在字符:\ ,反斜杠在代码里是转义字符,这个有点代码基础

的应该都知道。

不懂什么叫转义字符的,自己翻书补下基础吧!

遇到转义字符,为了不让转义,有两种处理方式:

第一种:\ (前面再加一个反斜杠)

第二种:r”\"(字符串前面加 r,使用字符串原型)

文件上传是 web 页面上很常见的一个功能,自动化成功中操作起来却不是那么简 单。

一般分两个场景:一种是 input 标签,这种可以用 selenium 提供的 send_keys() 方法轻松解决;

另外一种非 input 标签实现起来比较困难,可以借助 autoit 工具或者 SendKeys 第三方库。

非 input 标签的文件上传,就不适用于此方法了,需要借助 autoit 工具

或者 SendKeys 第三方库

# 获取浏览器名称
print driver.name

#获取页面源码

driver.page_source

page = driver.page_source
# print page
# "非贪婪匹配,re.S('.'匹配字符,包括换行符)" url_list = re.findall('href=\"(.*?)\"', page, re.S) url_all = []
for url in url_list:

       if "http" in url:
               print url

url_all.append(url) # 最终的 url 集合

print url_all

#获取cookies

driver.get_cookies()

用 get_cookie(name),指定对应的 cookie 的 name 值

清除指定cookie:delete_cookie(key=".value")

清除所有cookies:delete_all_cookies()

1.get_cookies():获取所有 cookies

2.driver.get_cookie(name):获取指定 name 的 cookie:

3.清除指定 cookie:delete_cookie()

4.delete_all_cookies():清除所有 cookies

5.add_cookie(cookie_dict):添加 cookie 的值

cookie ={u'domain': u'.cnblogs.com',
                       u'name': u'.CNBlogsCookie',
                    u'value': u'xxxx',
                      u'expiry': 1491887887,
                       u'path': u'/',
                    u'httpOnly': True,
                    u'secure': False}

name:cookie 的名称
value:cookie 对应的值,动态生成的

domain:服务器域名

"value";

expiry:Cookie 有效终止日期

path:Path 属性定义了 Web 服务器上哪些路径下的页面可获取服务器设置的 Cookie

httpOnly:防脚本攻击

secure:在 Cookie 中标记该变量,表明只有当浏览器和 Web Server 之间的通信 协议为加密认证协议时,

浏览器才向服务器提交相应的 Cookie。

当前这种协议只有一种,即为 HTTPS

# # 添加 cookie
c1 = {u'domain': u'.cnblogs.com', u'name': u'.CNBlogsCookie', u'value': u'xxxx', u'expiry': 1491887887, u'path': u'/', u'httpOnly': True, u'secure': False}

c2 = {u'domain': u'.cnblogs.com', u'name': u'.Cnblogs.AspNetCore.Cookies', u'value': u'xxxx', u'expiry': 1491887887, u'path': u'/', u'httpOnly': True, u'secure': False}

driver.add_cookie(c1)

driver.add_cookie(c2)

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值