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)