# 导入selenium的webdriver模块css
from selenium import webdriver
# 打开火狐浏览器web
wd = webdriver.Firefox()
# 使用火狐浏览器打开网址 浏览器
wd.get("http://babyplan.once.wiki/BabyPlan/login.jsp")
# 刷新当前页面框架
wd.refresh()
# 让浏览器进行后退操做jsp
wd.back()
#让浏览器进行前进操做函数
wd.forward()
设置窗口大小:ui
1.设置浏览器的分辨率,第一个参数(666)是设置浏览器的宽,第二个参(100)数设置浏览器的高度url
wd.set_window_size(666,100)
2.将浏览器窗口最大化spa
wd.maximize_window()
# 获取当前浏览器页面的截图,而且指定图片的保存位置插件
wd.get_screenshot_as_file("d:/a.png")
退出:
1.关闭当前正在使用的页面
wd.close()
2.关闭当前全部经过同一个webdriver打开的页面
wd.quit()
定位
1.经过id定位,定位到当前网页上ID为""的元素,而后将"233"这个值插入进去
wd.find_element_by_id("id").send_keys("233")
2.方法同上,经过name定位
wd.find_element_by_name("")
3.方法同上,经过class定位
wd.find_element_by_class_name("")
#按钮
使用ID定位到loginbtn后,使用“点击”操
wd.find_element_by_id("loginbtn").click()
#连接
1. 经过匹配超连接上面的文原本进行定位
wd.find_element_by_link_text("注册").click()
2.经过匹配超连接上面的文本进行定位,可是这种匹配是模糊的,能够不将文本补全
wd.find_element_by_partial_link_text("注").click()
#利用插件定位
浏览器:Firefox
安装插件:Firebug和FirePath设置(在菜单栏中的附加组件中)
1.经过使用firepath插件获取到具体的表达式来实现元素的定位
wd.find_element_by_xpath(".//*[@id='loginForm']/a").click()
2.经过FirePath插件选择css。经过样式来定位到具体的元素,这种方法在没有id 超连接等方式定位时,能够对元素进行准确的定位(前提是页面元素的样式比较丰富)
wd.find_element_by_css_selector(".userReg").click()
等待方法:
1.强制等待:什么都无论,调用time函数,直接让程序等待必定时间后在执行下一步操做
import time
time.sleep("等待时长")
2.显式等待:设置一个等待时长,每隔一段时间就会尝试执行语句,若是执行语句为真,则往下运行,若是为假,则继续等待,等到等待时长超限制,则抛出异常
WebDriverWait(调用的方法(wd),等待时长,每隔多长时间进行检查(默认为0.5秒)).until(要执行的语句)
from selenium.webdriver.support.wait import WebDriverWait
w(wd, 10).until(lambda x: x.find_element_by_link_text(u"注册").is_displayed())
# 使用显示等待的方法,判断注册按钮是否存在(displayed:存在),判断成立后再执行后面的内容,判断不成立,则等待限制时长后再跑出异常
3.隐式等待: 全局等待时长,设置脚本在网页加载过程当中的等待时长(当浏览器在等待时间内仍然在加载,转圈圈的状况下,则等待,加载完成后若是仍在时长范围内,也会继续执行下面的语句),超过期长后执行后面的语句
from selenium import webdriver wd = webdriver.Firefox() wd.implicitly_wait(5)
多窗口,多句柄
在平时的操做过程当中,正常都是使用同一个页面,可是有时候由于点击了某个连接,会出现一个新的窗口,
那么这个时候,系统是不知道咱们要操做哪个窗口的
所以咱们须要有一个东西来让系统知道咱们要操做的内容,就有了句柄这个东西
句柄的话能够理解成每一个不一样窗口都是有本身的一个标识符,至关与身份证同样,在浏览器里面,句柄就是页面的身份证
# 获取当前正在操做的页面(句柄)
wd.current_window_handle
# 获取当前全部的页面(句柄)
wd.window_handles
# 切换页面(句柄)
wd.switch_to_window("句柄值")
# 切换到当前页面的弹出窗口
wd.switch_to_alert()
# 执行弹出窗口的确认操做
wd.switch_to_alert().accept()
# 取消弹出窗口的确认操做
wd.switch_to_alert().dismiss()
# 定位到ID为loginForm的表单,而后执行提交操做,这样就不用再去找提交按钮了
wd.find_element_by_id("loginForm").submit()
元素操做
简单操做:
1.点击(鼠标左键)页面按钮:click()
2.清空输入框:clear()
3.输入字符串:send_keys()
模拟键盘操做
# 导入模拟键盘模块
from selenium.webdriver.common.keys import Keys
#模拟键盘使用:
send_keys(Keys.要使用的按键)
# 定位到ID为password的元素后,模拟键盘进行回车键的操做
wd.find_element_by_id("password").send_keys(Keys.ENTER)
模拟鼠标操做
#导入鼠标事件模块
from selenium.webdriver.common.action_chains import ActionChains
# 将wd对象绑定到鼠标方法
a = ActionChains(wd)
# 将获取到的元素地址赋值给b
b = wd.find_element_by_link_text("游戏中心")
# 执行鼠标方法的移动到对象上方,指定要移动的对象,鼠标悬停
a.move_to_element(b)
经常使用鼠标事件:
1.右击鼠标:context_click()
a.context_click(b)
2.双击鼠标:double_click()
a.double_click(b)
页面里面包含子页面的方法(框架)
# 使用switch方法切换到子页面里面去,方法参数为子页面id,切换完成以后才能对子页面的内容进行操做
wd.switch_to_fram("top")
# 切换到子页面里面后,当前位置就不是在本来页,所以要操做其余页面以前,要先跳出来
wd.switch_to_default_content()
获取元素属性
#获取当前页面的标题(HTML里面的title)
wd.title
# 获取标签的文本信息
wd.find_element_by_id("user").text
获取页面属性
# 定位到对应元素后,可使用get_attribute获取到标签里面任意属性的值(只要有)
wd.find_element_by_id("kw").get_attribute("name")
# 获取当前浏览器的名称
wd.name
# 获取当前页面的地址
wd.current_url