美文网首页
Selenium Webdriver Api

Selenium Webdriver Api

作者: 阿飞666666 | 来源:发表于2020-04-09 23:26 被阅读0次

    (一)Webdriver概述

          Webdriver (Selenium3)是一种用于Web应用程序的自动测试工具,它提供了一套友好的API,与Selenium 1(Selenium-RC)相比,Webdriver 的API更容易理解和使用,其可读性和可维护性也大大提高。Webdriver完全就是一套类库,不依赖于任何测试框架,除了必要的浏览器驱动,不需要启动其他进程或安装其他程序,也不必像Selenium 1那样需要先启动服务。

    (二)支持浏览器

    Firefox(FirefoxDriver)

    IE(InternetExplorerDriver)

    Opera(OperaDriver)

    Chrome(ChromeDriver)

    safari(SafariDriver)

    (三)支持语言

    Java

    C#

    PHP

    Python

    Perl

    Ruby

    (四)元素定位

    1.By.id:driver.findElement(By.id("id));

    2.By.name:driver.findElement(By.name("name"));

    3.By.xpath:driver.findElement(By.xpath("//input[@id='id']")); 

    4.By.className:driver.findElement(By.className("input_class"));

    5.By.cssSelector:driver.findElement(By.cssSelector(".input_class"));

    6.By.linkText:driver.findElement(By.linkText("link"));

    7.By.partialLinkText:driver.findElement(By.partialLinkText("link"));

    8.By.tagName:driver.findElement(By.tagName("form"));

    (五)元素操作

    1.driver.get(url):  #浏览器加载url。   

    2.driver.forward():#浏览器向前(点击向前按钮)。

    3.driver.back():#浏览器向后(点击向后按钮)。

    4.driver.refresh():#浏览器刷新(点击刷新按钮)。

    5.driver.close():#关闭当前窗口,或最后打开的窗口。

    6.driver.quit():关闭所有关联窗口,#并且安全关闭session。

    7.driver.maximize_window():  #最大化浏览器窗口。

    8.driver.set_window_size(宽,高):#设置浏览器窗口大小。

    9.driver.get_window_size():#获取当前窗口的长和宽。

    10.driver.get_window_position(): #获取当前窗口坐标

    11.driver.get_screenshot_as_file(filename):  #截取当前窗口。

    12.driver.implicitly_wait(秒): #隐式等待,通过一定的时长等待页面上某一元素加载完成。若提前定位到元素,则继续执行。若超过时间未加载出,则抛出NoSuchElementException异常。 

    13.driver.switch_to_frame(id或name属性值): #切换到新表单(同一窗口)。若无id或属性值,可先通过xpath定位到iframe,再将值传给switch_to_frame()

    14.driver.switch_to.parent_content(): #跳出当前iframe标签内嵌的表单(往上回退一级目录)。该方法默认对应于离它最近的switch_to.frame()方法。

    15.driver.switch_to.default_content(): #跳回最外层的html页面。

    16.driver.switch_to_window(窗口句柄):#切换到新窗口。

    17.driver.switch_to_alert(): #警告框处理。处理JavaScript所生成的alert,confirm,prompt.

    18.driver.execute_script(js): #调用js。

    19.driver.get_cookies(): #获取当前会话所有cookie信息。

    20.driver.get_cookie(cookie_name):#返回字典的key为“cookie_name”的cookie信息。

    21.driver.add_cookie(cookie_dict):添加cookie。#“cookie_dict”指字典对象,必须有name和value值。

    22.driver.delete_cookie(name,optionsString):#删除cookie信息。

    23.driver.delete_all_cookies(): #删除所有cookie信息。

    24.element.isDisplay();  #判断元素是否显示

    25.element.getAttribute() #得到元素的属性值 

    (五)键盘操作:

    导入Keys:from selenium.webdriver.common.keys import Keys

    回车:element.send_keys(Keys.ENTER)

    清理:element.clear()

    上:element.send_keys(Keys.ARROW_UP)

    下:element.send_keys(Keys.ARROW_DOWN)

    左:element.send_keys(Keys.ARROW_LEFT)

    右:element.send_keys(Keys.ARROW_RIGHT)

    向下:ActionChains(driver).send_keys(Keys.DOWN).perform()

    回车:ActionChains(driver).send_keys(Keys.ENTER).perform()

    (六)操作隐藏元素:

    方法1:

    js = ’document.querySelectorAll("select")[0].style.display="block";’

    方法2:

    js = "document.getElementById(\"txtPassword\").style.display='block';"

    其他方法:

    (getElementById():返回对指定ID第一个对象的引用

    getElementsByName() :返回带有指定名称的对象集合

    getElementsByTagName():返回带有指定标签名的对象集合)

    # 调用js脚本

    driver.execute_script(js)

    sleep(3)

    driver.find_element_by_id("txtPassword").send_keys("123456")

    (七)随机获取select下的值:

    方法1:

    select = browser.find_element_by_xpath("//form[@class='searchFrom']/div[6]/select")

    options_list = select.find_elements_by_tag_name("option")

    project = random.choice(options_list).get_attribute("value")

    print(project)

    方法2:

    select = Select(browser.find_element_by_xpath("//form[@class='searchFrom']/div[6]/select"))

    print(random.choice(select.options).get_attribute("value"))

    (八)拖拽元素:

    from selenium.webdriver import ActionChains

    action_chains = ActionChains(self.driver)

    action_chains.drag_and_drop(initialPositionElement, targetPositionElement).perform()

    for i in range(5):

    action_chains.drag_and_drop_by_offset(dragElement, 10, 10).perform()

    driver.get_screenshot_as_file(time.strftime("%H-%M-%S",time.localtime())+".png")

    (九)模拟键盘操作:

    from selenium.webdriver.common.keys import Keys

    query = self.driver.find_element_by_id("query")

    query.send_keys(Keys.F12)

    query.send_keys("selenium")

    query.send_keys(Keys.ENTER)

    (十)剪切板操作:

    import win32clipboard as w

    import win32con

    import time

    import win32api

    读取剪切板

    def getText():

    w.OpenClipboard()

    d = w.GetClipboardData(win32con.CF_TEXT)

    w.CloseClipboard()

    return d

    设置剪切板内容

    def setText(aString):

    w.OpenClipboard()

    w.EmptyClipboard()

    w.SetClipboardData(win32con.CF_UNICODETEXT, aString)

    w.CloseClipboard()

    VK_CODE = {

    'enter': 0x0D,

    'ctrl': 0x11,

    'a': 0x41,

    'v': 0x56,

    'x': 0x58

    }

    键盘键按下

    def keyDown(keyName):

    win32api.keybd_event(VK_CODE[keyName], 0, 0, 0)

    键盘键抬起

    def keyUp(keyName):

    win32api.keybd_event(VK_CODE[keyName], 0, win32con.KEYEVENTF_KEYUP, 0)

    模拟鼠标滚动

    for i in range(1, 1500):

    win32api.mouse_event(win32con.MOUSEEVENTF_WHEEL, 0, 0, -1)

    十一(By类)

    导入from selenium.webdriver.common.by import By

    定位方法:

    1.find_element(By.ID,"loginName")

    2.find_element(By.NAME,"SubjectName")

    3.find_element(By.CLASS_NAME,"u-btn-levred")

    4.find_element(By.TAG_NAME,"input")

    5.find_element(By.LINK_TEXT,"退出")

    6.find_element(By.PARTIAL_LINK_TEXT,"退")

    7.find_element(By.XPATH,".//*[@id='Title")

    8.find_element(By.CSS_SELECTOR,"[type=submit]")

    参考文献:https://www.cnblogs.com/bubutianshu/p/11179526.html,https://www.51zxw.com

    相关文章

      网友评论

          本文标题:Selenium Webdriver Api

          本文链接:https://www.haomeiwen.com/subject/poyqmhtx.html