关闭

Python+selenium web测试入门基础

发表于:2024-9-05 09:12

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:Nobody is me    来源:CSDN

  入门
  自动化测试框架
  from selenium import webdriver
  获取浏览器对象
  我这里是edge浏览器,用的是edge的webdriver
  # webdriver获取浏览器对象
  driver = webdriver.Edge()
  尝试打开网站并关闭
  # 准备一个网址
  url = "https://www.baidu.com/"
  driver.get(url)
  # 资源回收
  driver.quit()
  元素定位
  定位普通元素
  元素可通过 ID,NAME,CLASS_NAME查找(tagname不常用)
  driver.find_element(By.ID,"kw").send_keys("python")
  driver.find_element(By.NAME,"wd").send_keys("python")
  driver.find_element(By.CLASS_NAME,"s_ipt").send_keys("python")
  # 点击(click)id为su的控件
  driver.find_element(By.ID,"su").click()
  .send_keys() 表示往元素中填入内容。
  .click() 表示点击元素
  也可以通过css选择器,前缀为’#’ 代表ID值, ‘.’ 代表class值,[ ]可直接输入内容定位元素
  By.CSS_SELECTOR,'.s_ipt').send_keys('python')
  driver.find_element(By.CSS_SELECTOR,'[name=wd]').send_keys('python')
  driver.find_element(By.CSS_SELECTOR,'[value=百度一下]').click()
  xpath定位法,通过决定路径或属性查找的方式来定位元素。
  //* 代表全局查找符合条件的元素
  [@xx=”xxx” ] 代表查找属性xx等于xxx的元素,不带@就不是属性,一般用于搜索文本
  driver.find_element(By.XPATH,"//*[@id='kw']").send_keys('python')
  driver.find_element(By.XPATH,'//*[@id="su"]').click()
  定位a标签(链接标签)
  可通过linktext、partial linktext定位
  driver.find_element(By.LINK_TEXT,'hao123').click()
  driver.find_element(By.PARTIAL_LINK_TEXT,'hao').click()
  获取元素属性
  # 获取元素大小
  print(driver.find_element(By.ID, 'kw').size)
  # 获取元素文本
  print(driver.find_element(By.ID, 'kw').text)
  # 获取文本属性
  print(driver.find_element(By.XPATH, '//*[@id="s-top-left"]/a[1]').get_attribute('href'))
  # 元素是否可见
  print(driver.find_element(By.ID, 'kw').is_displayed())
  # 元素是否可用
  print(driver.find_element(By.ID, 'kw').is_enabled())
  获取网页属性
  # 获取页面title
  print(driver.title)
  # 获取网页url
  print(driver.current_url)
  # 浏览器后退
  driver.back()
  # 浏览器前进
  driver.forward()
  # 浏览器刷新
  driver.refresh()
  # 关闭当前页面
  driver.close()
  元素等待
  该操作主要是防止界面跳转后,新界面还未完全加载就进行操作步骤,从而导致代码找不到相应的元素而报错。
  强制等待
  通过time库,让程序强制停止一段时间,单位为秒。
  # 强制等待
  import time
  time.sleep(1)
  该方法比较死板,比较浪费时间,实际使用不太推荐,可在编写代码时用该方法查看代码运行效果。
  显示等待
  等待某个元素加载完成后继续运行代码,每0.5秒检测一次,如果出现该元素就运行代码,如果一直未出现(直到到达指定的时间),就会返回TimeOutException的错误。
  from selenium.webdriver.support.wait import WebDriverWait
  from selenium.webdriver.support import expected_conditions as EC
  WebDriverWait(driver,5).until(EC.presence_of_element_located((By.ID,'1')))
  优点:比较节省时间,在需要的元素出现时可直接开始运行代码,不必等待网页的全部加载。
  缺点:导入的库太多
  隐式等待
  driver.implicitly_wait(5)
  优点:不需要设定多个参数,也不需要导入库,在元素加载完毕后能够直接运行代码。
  缺点:因为没有明确等待的元素,所以隐式等待需要等待所有元素加载完毕在运行代码,在弱网状态时建议使用显示等待,让需要使用的元素出现时及时运行代码,节约时间。
  鼠标操作
  # 导入鼠标操作 库包
  from selenium.webdriver.common.action_chains import ActionChains
  # 鼠标右击
  action.context_click(driver.find_element(By.ID,'kw'))
  # 鼠标悬停
  action.move_to_element(driver.find_element(By.CLASS_NAME,'soutu-btn'))
  # 鼠标拖拽 第一个是拖拽目标,第二个是到达地址
  action.drag_and_drop(driver.find_element(xxx),driver.find_element(xxx))
  # 执行代码
  action.perform()
   键盘操作
  el = driver.find_element(By.ID,'kw')
  # 输入内容
  el.send_keys("python")
  # 全选
  el.send_keys(Keys.CONTROL,'a')
  # 删除
  el.send_keys(Keys.BACK_SPACE)
  # 复制
  el.send_keys(Keys.CONTROL,'c')
  # 粘贴
  el.send_keys(Keys.CONTROL,'v')
  下拉框的选择
   该功能用于下拉框的选择,用于网页的’<select>’模块选择。
  # 下拉框的库
  from selenium.webdriver.support.select import Select
  select = Select(driver.find_element(By.CSS_SELECTOR,'[name=city]'))
  # 通过index选择
  select.select_by_index(0)
  time.sleep(2)
  # 通过value选择
  select.select_by_value('sh')
  time.sleep(2)
  # 通过文字选择
  select.select_by_visible_text('成都')
  滚动条
  Python不能直接调用滚动条,但是可以使用js语言来调用。
  # 通过js语言进行滑动
  # 隐式等待无法滚动,滚动前不能添加隐式等待
  time.sleep(2)
  js_str = "window.scrollTo(0,10000)"
  driver.execute_script(js_str)
  警告框的处理
  该功能主要用于处理网页的报错警告框,例如网站的必读信息、登录过期等消息。
  # 警告框需要切换到警告框再处理
  alert = driver.switch_to.alert
  # 打印警告框内容
  print(alert.text)
  # 取消警告框
  alert.dismiss()
  # 确定警告框
  alert.accept()
  frame的切换
   该功能用于在某些网页中,网页内会内嵌一个网页,此时需要从原本的网页切换到内嵌的网页中,才能对内嵌的网页进行操作。
  driver.switch_to.frame(“frame元素的位置”)
  标签页的切换
   页面标签我们叫做habdle,其中可以通过两种方式获得页面的标签。
  # 获取页面 获取当前handle,新打开的页面在所有handle列表的最后面
  # 获取浏览器所有页面标签的list
  print(driver.window_handles)
  # 打印当前的页面标签
  print(driver.current_window_handle)
   每个新产生的页面标签都会排到list的后面,无论在浏览器上面怎么显示,新的页面标签就像用list.append()一样加入标签列表中。
  driver.switch_to.window(driver.window_handles[1])
  截图
  全屏截图并直接保存:
  driver.get_screenshot_as_file("截图.png")
   截图后按照png格式保存为Python的变量:
  shotpng = driver.get_screenshot_as_png()
  本文内容不用于商业目的,如涉及知识产权问题,请权利人联系51Testing小编(021-64471599-8017),我们将立即处理
《2024软件测试行业从业人员调查问卷》,您的见解,行业的声音!

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号