51Testing软件测试论坛

标题: 实用干货selenium常用的API(含源码) [打印本页]

作者: 韶光暗淡    时间: 2022-8-25 14:32
标题: 实用干货selenium常用的API(含源码)
1.八大元素定位方式driver.find_element_by_id(‘text’)

通过id去定位控件【在web端ID一般是唯一的】

  1. <font size="3"># <i id="cart_num">0</i>
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. driver.find_element_by_id('cart_num').click() # driver.find_element_by_id_text('cart_num')仅仅是定位到car_num控件,click()才是点击的动作
  8. </font>
复制代码
driver.find_element_by_name(‘text’)

通过name去定位控件【在web端name有可能是重复的,默认找的是第一个,如果报错一般会换其他方式】

  1. <font size="3"># <input class="but1" type="text" name="key" placeholder="请输入你要查找的关键字" value="">
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. driver.find_element_by_name('key').send_keys('王麻子')
  8. </font>
复制代码
driver.find_element_by_class_name(‘text’)

通过class去定位控件【对于属性值中间有空格的如’but bg’为复合类,不建议用class去定位,因为会报错】【所用控件必须具有链接属性】

  1. <font size="3"># <input class="but2" type="submit" value="搜索">
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. driver.find_element_by_class_name('but2').click()
  8. </font>
复制代码
driver.find_element_by_link_text(‘text’)

【传入值为a标签中间加的值】

  1. <font size="3"># <a href="http://101.133.169.100/yuns/index.php/goods?key=家装节" title="家装节">家装节</a>
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. driver.find_element_by_link_text('家装节').click()
  8. </font>
复制代码
driver.find_element_by_partial_link_text(‘text’)

【传入值部分匹配,如’T恤男’,‘男2016’,‘T恤男2’;注意传入值条件:1.必须唯一;2.必须连续】

  1. <font size="3"># <a href="http://101.133.169.100/yuns/index.php/goods?key=T恤男2016" title="T恤男2016" class="ch">T恤男2016</a>
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. driver.find_element_by_partial_link_text('T恤男').click()
  8. </font>
复制代码
driver.find_element_by_xpath
  1. <font size="3"># <input class="but1" type="text" name="key" placeholder="请输入你要查找的关键字" value="">绝对路径不适用于页面层级太深的
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. driver.find_element_by_xpath("/html/body/div/div/div/div/form/input[1]").click()  # 绝对路径/
  8. driver.find_element_by_xpath("//input[@class='but1']").click()  # 相对路径// 1.(单条件定位)用属性定位@后跟属性class或其他,=后为唯一值;2.(多条件定位)('//input[@name='key' and @class='but1']')
  9. driver.find_element_by_xpath("//input[@class='but1']").click()  # 单条件定位
  10. driver.find_element_by_xpath("//input[@name='key'and @class='but1']").click()  # 多条件定位
  11. driver.find_element_by_xpath("//input[contains(@placeholder,'请输入')]").click()  # 属性值模糊定位
  12. driver.find_element_by_xpath("//a[text()='家装节']").click()  # 值条件定位
  13. driver.find_element_by_xpath("//*[text()='家装节']").click()  # 值条件定位,*代表正则匹配,只要是text值为家装节的就可以被搜索到
  14. driver.find_element_by_xpath("//div[@class='schbox']/form/input[1]").click()  # 父级定位 爸找儿子
  15. driver.find_element_by_xpath("//input[@class='but1']/..").click()  # 子级定位 儿子找爸
  16. driver.find_element_by_xpath("//input[@class='but1']/../input[2]").click()  # 兄弟定位,子级定位再父级定位
  17. </font>
复制代码
driver.find_element_by_css_selector

注意不同标签,css-selector也会一同排序
写绝对路径最好用xpath

  1. <font size="3"># <input class="but1" type="text" name="key" placeholder="请输入你要查找的关键字" value="">
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. driver.find_element_by_css_selector("html>body>div>div>div>div>form>input").click()  # 绝对路径
  8. driver.find_element_by_css_selector("i#cart_num").click()  # id定位 【i是标签名,用id定位必须是#】
  9. driver.find_element_by_css_selector("input.but1").click()  # class定位
  10. driver.find_element_by_css_selector("input[placeholder='请输入你要查找的关键字']").click()  # 搜索值唯一定位
  11. driver.find_element_by_css_selector("input[name='key'][class='but1']").click()  # 多条件定位
  12. driver.find_element_by_css_selector("div.schbox>form>input:nth-child(1)").click()  # 父级定位
  13. driver.find_element_by_css_selector("div.schbox>form>input:first-child").click()  # 父级定位-第一个
  14. driver.find_element_by_css_selector("div.schbox>form>input:last-child").click()  # 父级定位-最后一个
  15. driver.find_element_by_css_selector("div.schbox>form>input:nth-last-child(2)").click()  # 父级定位-倒数第二个
  16. driver.find_element_by_css_selector("form#form>span:nth-child(9)>input").click()  # css是不同标签一同排序,比如span和div【此处id为form,第一个form为标签名】
  17. </font>
复制代码
driver.find_element_by_tag_name

页面的tag实在是太多了,因此一般用做计数标签数量,

  1. <font size="3"># <input class="but1" type="text" name="key" placeholder="请输入你要查找的关键字" value="">
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. aa = driver.find_elements_by_tag_name('div')
  8. print(len(aa))
  9. </font>
复制代码
2.操作(1)获取验证信息

driver.current_url:对于要获取点击的文本链接信息,则需要先点击,才能再获取。
driver.title:直接获取当前网页的title信息

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  5. driver.maximize_window()

  6. title = driver.title  # 获取网页的title信息【网页标签的名字】

  7. driver.find_element_by_link_text("联系客服").click()
  8. url = driver.current_url  # 获取当前跳转后的页面地址

  9. print(title)
  10. print(url)
  11. </font>
复制代码
(2)页面控制

driver.refresh():刷新
driver.back():回退
driver.forward():前进

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  5. driver.maximize_window()

  6. driver.refresh()  # 刷新
  7. time.sleep(2)
  8. driver.back()  # 回退
  9. time.sleep(2)
  10. driver.forward()  # 前进
  11. time.sleep(2)
  12. </font>
复制代码
(3)窗体设置

driver.maximize_window():窗体最大化
driver.set_windows_size(1200,720):设置窗体长1200宽720

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  5. driver.maximize_window()  # 窗体最大化
  6. driver.set_windows_size(1200,720)  # 设置窗体宽1200高720
  7. </font>
复制代码
(4)动作事件

定位控件.send_keys(‘text’):对定位控件输入内容text
定位控件.clear():对定位空间清空内容
定位控件.click():点击定位控件

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  5. driver.maximize_window()

  6. driver.find_element_by_name('key').send_keys('王麻子')  # 输入内容
  7. driver.find_element_by_name('key').clear()  # 清空输入内容
  8. driver.find_element_by_partial_link_text('T恤男').click()  # 点击
  9. </font>
复制代码
(5)获取属性数据
定位控件.size:获取控件长宽数据,数据类型为字典{‘height’:’’,‘weihght’:’’}
定位控件.text:获取控件上文本信息
定位控件.get_attribute(“href”):获取控件内默认信息,href为属性名
定位控件.get_attribute(‘value’) : 固定传value,在输入内容后获取其回显信息【先输入内容在获取回显信息】
定位控件.is_displayed():判断控件是否显示
  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  5. driver.maximize_window()

  6. size = driver.find_element_by_name('key').size  # 获取控件长宽数据,获取的数据类型为字典{'height':'','weihght':''}
  7. text = driver.find_element_by_name('key').text  # 获取控件上文本信息
  8. at = driver.find_element_by_name('key').get_attribute("href")  # 获取控件内默认信息,href为属性名
  9. dis = driver.find_element_by_name('key').is_displayed()  # 判断是否显示,true/false
  10. text = driver.find_element_by_name('key').get_attribute('value')  # 固定传value拿到输入后的回显信息
  11. </font>
复制代码
(6)鼠标事件
ele = 定位控件
ActtionChains(driver).move_to_element(ele).perform():将鼠标移动到定位控件上悬停【类似于hover】
ActtionChains(driver).context_click(ele).perform():鼠标右击定位控件
ActtionChains(driver).double_click(ele).perform():鼠标双击定位控件

scour = driver.find_element_by_xpath(""):确定拖拽目标的起点
target = driver.find_element_by_xpath(""):确定拖拽目标的终点
ActionChains(driver).drag_and_drop(scour,target):拖拽目标从起点到终点

ActionChains(driver).drag_and_drop_by_offset(scour,100,0):拖拽目标(起点,x值,y值)
  1. <font size="3">from selenium.webdriver.common.action_chains import ActionChains  # 引入 ActionChains 类
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. ele = driver.find_element_by_link_text("母婴玩具")
  8. ActtionChains(driver).move_to_element(ele).perform()  # 把鼠标移到某个控件上.perform()使动作生效
  9. ActtionChains(driver).context_click(ele).perform()  # 右击
  10. ActtionChains(driver).double_click(ele).perform()  # 双击
  11. # .perform() 运行动作

  12. # 拖动控件
  13. scour = driver.find_element_by_xpath("")
  14. target = driver.find_element_by_xpath("")
  15. ActionChains(driver).drag_and_drop(scour,target)

  16. ActionChains(driver).drag_and_drop_by_offset(scour,100,0)  # 偏移
  17. </font>
复制代码
(7)键盘事件
定位控件.send(‘女装’):输入数据
定位控件.keys(Keys.Back_SPACE):删除1个字符
定位控件.keys(Keys.SPACE):输入空格
定位控件.keys(Keys.CONTROL,‘a’):传入CTRL+a
定位控件.keys(Keys,ENTER):传入enter
注意:复制后需要重新选中粘贴才看得到效果【查看keys方法可以看见相应的键盘输入内容】
  1. <font size="3">from selenium.webdriver.common.keys import Keys  # 引入keys
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome() # 初始化webdriver类的对象
  5. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  6. driver.maximize_window()

  7. text = driver.find_element_by_name('key').send('女装')  # 输入数据
  8. text = driver.find_element_by_name('key').keys(Keys.Back_SPACE)  # 删除1个字符
  9. text = driver.find_element_by_name('key').keys(Keys.SPACE)  # 输入空格
  10. </font>
复制代码
(8)等待时间
因为代码执行的速度非常快,因此若不给以适当的等待时间,由于页面未加载完毕,可能会出现漏报甚至错报,所以加入等待时间。
time.sleep(4):强制等待时间【线程休眠,不进行执行操作,直到时间等待完才继续执行】
dirver.implicitly_wait(10):隐式等待时间,相当于最大等待时间(全局),如果只用了2s则无需等待10秒,便可继续执行后面操作【缺点是第一个是如果第一页的元素第二页也有,因为网络原因或其他原因加载慢了或是没加载出来,原本需要在第二个页面查找的元素,返回的元素却是第一个页面的元素,而且在该函数之后如果出现了强制等待时间,则会打破其的全局性,接下来的代码将不会有等待时间】
ele = WebDriverWait(driver,15,0.5).until(EC.presence_of_element_located((By.XPATH,“定位控件”))) /n ele.控件操作:显式等待时间【最大等待时间15s,每0.5秒检测一次,知直到当前页面加载出来xpath的xx的控件,才对其做相应操作】XPATH可为其他定位方法名如ID、CSS_SELECTOR、…
  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  5. driver.maximize_window()

  6. time.sleep(2)  # 强制等待时间,时间等待完才继续执行

  7. # 隐式等待时间
  8. dirver.implicitly_wait(10)  # 隐式等待时间,相当于最大等待时间(全局),如果只用了2s则无需等待10秒,便可继续执行后面操作【缺点是第一个是如果第一页的元素第二页也有,因为网络原因或其他原因加载慢了或是没加载出来,原本需要在第二个页面查找的元素,返回的元素却是第一个页面的元素】
  9. time.sleep(3)  # 而且在隐式等待时间下有time.sleep()则会打破全局的规则,而且之后代码执行也不会有时间等待
  10. </font>
复制代码
显式等待时间
from selenium.webdriver.support.ui import WebDriverWait # 显式等待时间所需要引入的模块
from selenium.webdriver.common.by import By # 显式等待时间所需要引入的模块
from selenium.webdriver.support import expected_conditions as EC # 显式等待时间所需要引入的模块
  1. <font size="3">from selenium.webdriver.support.ui import WebDriverWait  # 显式等待时间所需要引入的模块
  2. from selenium.webdriver.common.by import By  # 显式等待时间所需要引入的模块
  3. from selenium.webdriver.support import expected_conditions as EC  # 显式等待时间所需要引入的模块
  4. from selenium import webdriver # 导入selenium库里的webdriver模块
  5. import time

  6. driver = webdriver.Chrome() # 初始化webdriver类的对象
  7. driver.get('http://101.133.169.100/yuns/index.php') # 打开项目地址
  8. driver.maximize_window()

  9. # 最大等待时间15s,每0.5秒检测一次,知直到当前页面加载出来xpath的xx的控件
  10. ele = WebDriverWait(self.driver,15,0.5).until(EC.presence_of_element_located(
  11.         (By.XPATH,"//div[@class='schbox']/form/input[1]")))
  12. ele.send_keys("123456")

  13. ele = WebDriverWait(self.driver,15,0.5).until_not(EC.presence_of_element_located(
  14.         (By.XPATH,"//div[@class='schbox']/form/input[1]")))
  15. ele.send_keys("123456")
  16. </font>
复制代码
等待时间的时间怎么确认?以多次测试的最大等待时间+1s-2s为准

(9)多窗口
driver.switch_to.window(driver.window_handles[-1]):切换最新打开的窗体
driver.close():关闭当前句柄所在窗体
driver.quit():退出所有窗体
  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://www.baidu.com') # 打开项目地址
  5. driver.maximize_window()
  6. print(driver.windiws_handles)  # 打印当前所有窗体的信息
  7. driver.find_element_by_id('kw'),send_keys('123')
  8. driver.find_element_by_id('su').click()

  9. driver.find_element_by_partial_link_text('123网址').click()
  10. print(driver.windiws_handles)  # 打印当前所有窗体的信息
  11. print(driver.current_window_handle)  # 打印当前窗体所在句柄的信息
  12. driver.switch_to.window(driver.window_handles[1])  #切换句柄为1的新窗体
  13. driver.close()  #关闭当前句柄所在窗体
  14. driver.quit()  #所有浏览器退出
  15. </font>
复制代码
(10)弹窗处理
鼠标右击查看不了的弹出框就是alert
driver.switch_to.alert.send_keys(“test”):输入信息
print(driver.switch_to.alert.text) :获取信息
driver.switch_to.alert.accept() :点击确定【正向信息,如确定、提交】
driver.switch_to.alert.dismiss():点击取消【反向信息,如取消,删除等】
  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome() # 初始化webdriver类的对象
  4. driver.get('http://') # 打开项目地址
  5. driver.maximize_window()

  6. driver.switch_to.alert.send_keys("test")  #输入信息
  7. print(driver.switch_to.alert.text)  # 获取信息
  8. driver.switch_to.alert.accept()  # 点击确定
  9. driver.switch_to.alert.dismiss()  #点击取消

  10. </font>
复制代码
(11)截图

存储截图便于分析
driver.get_screenshot_as_file(“C:/Users/Hades/Desktop/name.png”):截图(当前句柄所在窗体)到真实地址,有路径和名称【png格式】

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome()  # 初始化webdriver类的对象
  4. driver.get('http://101.133.169.100/yuns/index.php')  # 打开项目地址
  5. driver.maximize_window()

  6. driver.get_screenshot_as_file("C:/Users/Hades/Desktop/name.png")   # 截图(当前句柄所在窗体)到真实地址
  7. </font>
复制代码

12)iframe网页嵌套

iframe是控件,frame是方法

有id/name且不变化,可用。

driver.switch_to.frame(‘x-URS-iframe’)括号里跟id/name直接切入iframe里【x-URS-iframe是id】


无id/name,先定位元素位置

dd = driver.find_element_by_xpath("//div[@id=‘loginDiv’]/iframe"):获取iframe的id或其他定位信息

driver.switch_to.frame(dd):先定位位置,再定位内部信息 ,


driver.switch_to.parent_frame():从子frame切回到父frame【层层嵌套】

driver.switch_to.default_content():切回主文档

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome()  # 初始化webdriver类的对象
  4. driver.get('https://mail.163.com')  # 打开项目地址
  5. driver.maximize_window()


  6. dd = driver.find_element_by_xpath("//div[@id='loginDiv']/iframe")  #获取id
  7. driver.switch_to.frame(dd)  #先定位位置,再定位内部信息

  8. driver.switch_to.frame('x-URS-iframe')  #有id,name 且不变化可用

  9. driver.switch_to.parent_frame()#从子frame切回到父frame
  10. driver.switch_to.default_content()#切回主文档
  11. </font>
复制代码

(13)select下拉选择框

s = driver.find_element_by_id(“j_roomCountList”):找到select控件,将其赋值给s

Select(s).select_by_visible_text(“2间”):定位到可见的文本信息【2间】

Select(s).select_by_index(3):用index定位,类似于列表,从0开始

Select(s).select_by_value(6)::用value的值定位

  1. <font size="3">from selenium.webdriver.support.select import Select  # 导入下拉选择框类
  2. from selenium import webdriver # 导入selenium库里的webdriver模块
  3. import time

  4. driver = webdriver.Chrome()  # 初始化webdriver类的对象
  5. driver.get('https://ctrip.com')  # 打开项目地址
  6. driver.maximize_window()

  7. emailname=driver.find_element_by_name('email')
  8. emaiiname.send_keys('testiframe')

  9. s = driver.find_element_by_id("j_roomCountList") # 找到select控件,将其赋值给s
  10. Select(s).select_by_visible_text("2间")  # 定位到可见的文本信息【2间】
  11. Select(s).select_by_index(3)  # 用index定位,类似于列表,从0开始
  12. Select(s).select_by_value(6)  # 用value的值定位

  13. </font>
复制代码

14)时间控件处理

可输入内容

ele = d.find_element_by_id(‘HD_CheckIn’):定位控件

ele.clear():控件内容清空

ele.send_keys(‘2021-05-16’):重新输入值


时间控件属性readonly='readonly’的

js = “document.getElementById(‘noticeEndTime’).removeAttribute(‘readonly’)” :移除readonly属性

d.execute_script(js) :执行js

d.find_element_by_name(“noticeEndTime”).send_keys(“2019-06-21 10:52:52”) :按照正常时间控件输入处理

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome()  # 初始化webdriver类的对象
  4. driver.get('https://ctrip.com')  # 打开项目地址
  5. driver.maximize_window()

  6. ele = d.find_element_by_id('HD_CheckIn')  # 定位控件
  7. ele.clear()  # 控件内容清空
  8. ele.send_keys('2021-05-16')  #重新输入值

  9. js = "document.getElementById('noticeEndTime').removeAttribute('readonly')" :移除readonly属性
  10. #js = "document.getElementsByName('noticeEndTime')[0].removeAttribute('readonly')"
  11. #js = "document.getElementsByTagName('input')[0].removeAttribute('readonly')"
  12. d.execute_script(js) :执行js
  13. d.find_element_by_name("noticeEndTime").send_keys("2019-06-21 10:52:52") :按照正常时间控件输入处理
  14. </font>
复制代码

**(15)**滚动条

js=“var q=document.documentElement.scrollTop=10000” # 一个js脚本给10000(足够大的数)滚动到页面最底部

driver.execute_script(js) # 执行js

driver.execute_script(“var q=document.documentElement.scrollTop=0”) # 执行js-滚动到页面最顶部

driver.execute_script(“window.scrollTo(0, document.body.scrollHeight*0.5)”) # 滚动到窗体高度的50%【scrollTo:到哪里;x方向是0,y方向为窗口body高度的50%,】

driver.execute_script(‘window.scrollBy(0,200)’) # 以当前位置为准【相对】(x方向为0,y方向向上偏移200)

driver.execute_script(‘window.scrollTo(0,1500)’) # 以当前位置为准【绝对】(x方向为0,y方向为1500)

  1. <font size="3">from selenium import webdriver # 导入selenium库里的webdriver模块
  2. import time

  3. driver = webdriver.Chrome()  # 初始化webdriver类的对象
  4. driver.get('https://ctrip.com')  # 打开项目地址
  5. driver.maximize_window()

  6. js="var q=document.documentElement.scrollTop=10000"  # 一个js脚本给10000(足够大的数)滚动到页面最底部
  7. driver.execute_script(js)  # 执行js

  8. js="var q=document.documentElement.scrollTop=0"  # 滚动到页面最顶部
  9. driver.execute_script(js)  # 执行js

  10. driver.execute_script("window.scrollTo(0, document.body.scrollHeight*0.5)")  # 滚动到窗体高度的50%【scrollTo:到哪里;x方向是0,y方向为窗口body高度的50%,】

  11. driver.execute_script('window.scrollBy(0,200)')  # 以当前位置为准【相对】(x方向为0,y方向向上偏移200)

  12. driver.execute_script('window.scrollTo(0,1500)')  # 以当前位置为准【绝对】(x方向为0,y方向为1500)
  13. </font>
复制代码

(16)文件上传

input标签

我们在做selenium自动化时,必须要面临的就是页面元素的定位,如果该上传文件功能的标签类型为input,例如:


以上类型的上传文件功能吗,我们可以直接使用selenium中的元素定位+send_keys()方法,括号内传入文件路径,例如:

driver.find_element_by_xpath("").send_keys(r"c:/test.png")

以上是针对于元素类型为input可直接使用selenium上传。


验证码

用selenium来获取获取cookies。

因为经常会出现验证码,导致我们ui自动化测试工作无法更好开展,那么如何处理这种验证码呢?

[attach]141904[/attach]

像这种滑块和手机验证码的情况下,无法通过正常办法是没有办法进行处理,那么 一般对这种处理有以下几种思路:

1、 通过接口请求,拿到对应验证码信息

2、 让开发配合把验证码搞成万能验证码

3、 注入cookies


那么如何通过注入cookies的形式来实现呢?

首先我们先通过自动化形式打开我们登录页面,此时我们加一定的延时时间,手动登录后,打印出来cookies信息,此时我们就知道所需要的cookies信息了。

  1. <font size="3">driver = webdriver.Chrome()
  2. driver.get("https://fly.layui.com/user/login/")
  3. time.sleep(30)
  4. cookies = driver.get_cookies()
  5. print (cookies)
  6. </font>
复制代码

复制代码
这样你之前的cookies信息就会存在cookies的json文件中,下次要去使用就直接读文件就好了,具体实现如下:
2、自动化代码的注入cookies办法:

  1. <font size="3">driver = webdriver.Chrome()
  2. driver.get("https://fly.layui.com/user/login/")
  3. time.sleep(3)
  4. with open('cookiesFile.json','r') as filemy:
  5.      cookiesInfo=json.loads(filemy.read())
  6. for cc in range(0,len(cookiesInfo)):
  7.     driver.add_cookie(cookiesInfo[cc])
  8. driver.refresh()
  9. </font>
复制代码

复制代码此时通过refresh后,我们就直接登入了系统,是不是很方便呢?

另外需要注意的是:

77版本的Chrome浏览器:对于 ‘expiry’ 参数,不支持float类型上传,这参数表示过期时间,给浏览器添加时,

浏览器只识别整形的,多少秒。 需要将driver.get_cookies() 得到的Cookies,变为整型,才可做cookie绕过验证码登录。

  1. <font size="3">for i in cookies:
  2.     if 'expiry' in i and i['expiry'] is  not None
  3.         i['expiry']= int(i['expiry'])
  4. </font>
复制代码











欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2