# 导入selenium的webdriver模块
from selenium import webdriver
# 打开火狐浏览器
wd = webdriver.Firefox()
# 使用火狐浏览器打开网址
wd.get("http://babyplan.once.wiki/BabyPlan/login.jsp")
# 刷新当前页面
wd.refresh()
# 让浏览器进行后退操作
wd.back()
#让浏览器进行前进操作
wd.forward()
设置窗口大小:
1.设置浏览器的分辨率,第一个参数(666)是设置浏览器的宽,第二个参(100)数设置浏览器的高度
wd.set_window_size(666,100)
2.将浏览器窗口最大化
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