selenium基本操作

# 导入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
原文地址:https://www.cnblogs.com/G-MingYin/p/7497410.html