web自动化测试工具之Selenium的使用(2)

发表于:2023-11-07 09:39

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

 作者:CodeDevMaster    来源:稀土掘金

  常见方法
  driver对象
  在使用selenium过程中,实例化driver对象后,driver对象有一些常用的属性和方法
  driver.page_source 当前标签页浏览器渲染之后的网页源代码
  driver.current_url 当前标签页的url
  driver.close() 关闭当前标签页,如果只有一个标签页则关闭整个浏览器
  driver.quit() 关闭浏览器
  driver.forward() 页面前进
  driver.back() 页面后退
  driver.screen_shot(img_name) 页面截图
  定位标签元素与获取标签对象
  在selenium中可以通过多种方式来定位标签,返回标签元素对象
  旧版本
  find_element_by_xxx 返回第一个符合条件
  find_elements_by_xxx 返回符合条件所有元素的WebEelemnt列表
  find_element匹配不到就抛出异常,find_elements匹配不到就返回空列表
  find_element_by_id 通过ID
  find_element_by_class_name 通过class查询元素
  find_element_by_name 通过name
  find_element_by_tag_name 通过标签名称
  find_element_by_css_selector css样式选择
  find_element_by_link_text 通过链接内容查找
  find_element_by_partial_link_text 通过链接内容包含的内容查找,模糊查询
  find_element_by_xpath 通过xpath查找数据
  新版本
  find_element(BY, 'str')
  find_elements(BY, 'str')
  find_element(By.ID, 'id')
  find_element(By.CLASS_NAME, 'calss_name')
  find_element(By.NAME, 'name')
  find_element(By.TAG_NAME, 'tag_name')
  find_element(By.CSS_SELECTOR, 'css_selector')
  find_element(By.LINK_TEXT, 'link_text')
  find_element(By.PARTIAL_LINK_TEXT, 'partial_link_text')
  find_element(By.XPATH, 'xpath')
  获取文本内容与属性值
  获取元素属性值
  element.get_attribute('属性名')
  获取元素文本内容
  element.text
  向输入框输入数据
  input_element.send_keys('selenium')
  对元素执行点击操作
  button_element.click()
  使用无界面浏览器
  绝大多数服务器是没有界面的,selenium控制谷歌浏览器也是存在无界面模式的,无界面模式又称之为无头模式。
  使用pyantomjs驱动
  不推荐使用pyantomjs驱动,pyantomjs方式已被Selenium淘汰
  下载地址:http://phantomjs.org/download.html
  使用方式:
  # 导入模块
  import time
  from selenium import webdriver
  # 创建浏览器对象
  browser = webdriver.PhantomJS(executable_path=r"D:\Development\phantomjs-2.1.1-windows\bin\phantomjs.exe")
  # 指定操作浏览器对象的行为
  # 让浏览器访问网页
  browser.get("https://www.baidu.com/")
  # 保存截图调试
  browser.save_screenshot('screenshot.png')
  异常1:
  新版的 selenium已经放弃PhantomJS,所以会出现AttributeError: module 'selenium.webdriver' has no attribute 'PhantomJS'异常。
  卸载selenium
  pip uninstall selenium
  安装selenium指定版本
  pip install selenium==3.14.0
  异常2:
  selenium.common.exceptions.WebDriverException: Message: 'phantomjs.exe' executable needs to be in PATH. 
  方案一:在完整路径前面加了一个r
  browser = webdriver.PhantomJS(executable_path=r"D:\Development\phantomjs-2.1.1-windows\bin\phantomjs.exe")
  方案二:将bin文件的路径添加到系统变量
  C:\Users\Admin>phantomjs -v
  2.1.1
  设置chrome启动参数
  # 导入模块
  from selenium import webdriver
  # 创建浏览器对象,指定配置参数
  options = webdriver.ChromeOptions()
  options.add_argument('--headless')  # 开启无界面模式
  options.add_argument('--disable-gpu')  # 禁用gpu
  # 实例化带有配置对象的driver对象
  browser = webdriver.Chrome('D:\Development\chromedriver_win32\chromedriver.exe', chrome_options=options)
  # 指定操作浏览器对象的行为
  # 让浏览器访问网页
  browser.get("https://www.baidu.com/")
  # 保存截图调试
  browser.save_screenshot('screenshot.png')
  其他操作
  窗口切换
  浏览器可能会打开多个网页,需要定位当前获取的网页元素是哪个窗体。通过 browser.switch_to.window 切换窗口。
  # 获取当前所有的窗口
  print(browser.window_handles)
  # 获取当前选中窗体的名称
  print(browser.current_window_handle)
  print("切换前:", browser.title)
  # 执行js新开一个标签页
  js = 'window.open("https://www.baidu.com");'
  browser.execute_script(js)
  time.sleep(3)
  # 获取当前所有的窗口
  print(browser.window_handles)
  # 切换窗体
  browser.switch_to.window(browser.window_handles[1])
  print("切换后:", browser.title)
  ifrme切换
  iframe是html中常用的一种技术,即一个页面中嵌套了另一个网页。
  浏览器网页中可能包含iframe网页,selenium默认是访问不了frame中的内容的,因此需要获取iframe网页元素。通过browser.switch_to.frame切换iframe。
  import time
  # 导入模块
  from selenium import webdriver
  # 创建浏览器对象
  # 参数驱动路径
  from selenium.webdriver.common.by import By
  browser = webdriver.Chrome()
  browser.get("https://mail.qq.com/cgi-bin/loginpage")
  print("切换前:", browser.page_source)
  # 获取iframe元素对象
  iframe_element = browser.find_element(By.ID, 'login_frame')
  # 切换 iframe
  browser.switch_to.frame(iframe_element)
  print("切换后:", browser.page_source)
  # 切换回 主窗口
  browser.switch_to.default_content()
  print("切回后:", browser.page_source)
  # 利用切换标签页的方式切出frame标签
  # windows = driver.window_handles
  # driver.switch_to.window(windows[0])
  time.sleep(5)
  # 退出浏览器
  browser.quit()
  设置User-Agent和代理
  selenium控制谷歌浏览器时,User-Agent默认是谷歌浏览器的,其是可以被替换的。
  selenium控制浏览器也是可以使用代理ip的。
  options = webdriver.ChromeOptions()
  # 切换User-Agent
  options.add_argument('--user-agent=Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 Mobile/15A372 Safari/604.1')
  # 设置代理
  options.add_argument('--proxy-server=代理服务器地址') # 设置代理
  browser = webdriver.Chrome('./chromedriver',chrome_options=options)
  获取网页源码
  获取的网页源码是经过JS页面执行后的结果源码
  browser.page_source
  cookies操作
  selenium能够帮助处理页面中的cookie。
  获取所有Cookies
  browser.get_cookies()
  把cookie转化为字典
  cookies_dict = {cookie['name']: cookie['value'] for cookie in browser.get_cookies()}
  通过名字获取Cookie
  browser.get_cookie()
  添加Cookie
  browser.add_cookie()
  通过名字删除Cookie
  browser.delete_cookie()
  删除所有Cookie
  browser.delete_all_cookies()
  执行javascript
  selenium可以让浏览器执行指定的js代码
  # js语句:滚动
  js = 'window.scrollTo(0,document.body.scrollHeight)' 
  # 执行js的方法
  browser.execute_script(js) 
  js ="alert("hello world")"
  browser.execute_script(js)
  页面等待
  页面在加载的过程中需要花费时间等待网站服务器的响应,在这个过程中标签元素有可能还没有加载出来,同时又去获取数据导致浏览器寻找不到需要操作的元素时从而引发异常。此时就需要程序进行等待,有如下3种方式。
  selenium页面等待分类
  强制等待
  隐式等待
  显式等待
  1.强制等待
  设置时间太短,元素没有加载出来。设置时间太长,会浪费时间
  time.sleep(秒数)
  2.隐性等待
  隐式等待针对的是元素定位,隐式等待设置了一个时间,在一段时间内判断元素是否定位成功,如果完成了,就进行下一步。在设置的时间内没有定位成功,则会报超时加载
  browser.implicitly_wait(等待时间)
  3.显性等待,每个元素都可以自己定义检查条件
  每经过多少秒就查看一次等待条件是否达成,如果达成就停止等待,继续执行后续代码。如果没有达成就继续等待直到超过规定的时间后,报超时异常
  1.手动实现页面等待
  t = time.time()
  # 定义超时时间
  timeout = 60
  while True:
      try:
          # 超时时间间隔
          time.sleep(1)
          url_element = browser.find_element(BY.ID, "OK")
          break
      except:
          # 超时处理
          if time.time() - t > timeout:
              break
          pass
  2.提供显性等待API
  # 等待对象模块
  from selenium.webdriver.support.wait import WebDriverWait
  # 导入等待条件模块
  from selenium.webdriver.support import expected_conditions as EC
  # 导入查询元素模块
  from selenium.webdriver.common.by import By
  # 使用selenium api 实现显性等待
  # 创建等待对象,传入:浏览器对象、超时时间、检查元素时间间隔
  wait = WebDriverWait(browser, 60, 0.1)
  # 检查元素是否存在,参数是一个元祖,元祖内部描述等待元素查询方案
  # EC.presence_of_element_located()
  # 检查元素是否可见
  # EC.visibility_of_element_located()
  url_element = wait.until(EC.presence_of_element_located((By.CLASS_NAME, "OK")))
  本文内容不用于商业目的,如涉及知识产权问题,请权利人联系51Testing小编(021-64471599-8017),我们将立即处理
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

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

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

沪ICP备05003035号

沪公网安备 31010102002173号