zoukankan      html  css  js  c++  java
  • selenium 难定位元素,时间插件,下拉框定位,string

    1.元素定位

    ID定位元素:

     findElement(By.id(“”)); 

    通过元素的名称定位元素:

     findElement(By.name(“”));  

    通过元素的html中的位置定位元素:

    findElement(By.xpath(“”)); 

    通过元素的标签名称定位元素:

    findElement(By.tagName(“”)); 

    通过元素的链接名称定位元素:

     findElement(By.linkText(“”)); 

    通过元素的类名定位元素:

     findElement(By.className(“”)); 

    通过元素的css定位元素:

     findElement(By.cssSelector(“”)); 

    通过元素的部分链接名称定位元素:

     findElement(By.partialLinkText(“”));

     

    2.元素操作

    driver.findElement(By.id(element)).click();

    driver.findElement(By.id(element)).sendKeys(“123456”);

    WebElement text1 = driver.findElement(By.name("password"));
    text1.sendKeys("123456");

    3,页面操作

    打开网页:driver.get("https://www.baidu.com");

    关闭网页:driver.close();

    在输入框中输入内容:text.sendKeys(“”);

    清空输入框中的内容:text.clear();

    获取输入框中的内容:text.getText();

    选择下拉框中的元素:

    Select select = new Select(wd.findElement(By.id("select")));

    切换到某个frame:

    driver.switchTo().frame("");

    从一个frame切换到另一个frame:

    driver.switchTo().frame("");

    切换到某个window:

    driver.switchTo().window("windowName");

    返回父iframe:(一般在跳转frame之前都写上这个语句)

    driver.switchTo().defaultContent();

    刷新页面:driver.navigate().refresh();

    页面前进后退:

    driver.navigate().forward();

    driver.navigate().back();

    3,输入框

    element.sendKeys(“test”);//在输入框中输入内容:

    element.clear();       //将输入框清空

    element.getText();     //获取输入框的文本内容: 

    4.下拉选择框

    Select select = new Select(driver.findElement(By.id("select")));  

    select.selectByVisibleText(“A”);

    select.selectByValue(“1”); 

    select.deselectAll();

    select.deselectByValue(“1”);

    select.deselectByVisibleText(“A”);

    select.getAllSelectedOptions();

    select.getFirstSelectedOption(); 

    5.单选框

    WebElement radio=driver.findElement(By.id("BookMode"));

    radio.click();       //选择某个单选项

    radio.clear();      //清空某个单选项

    radio.isSelected();  //判断某个单选项是否已经被选择

    6.多选框

    WebElement checkbox = driver.findElement(By.id("myCheckbox."));

    checkbox.click();

    checkbox.clear();

    checkbox.isSelected();

    checkbox.isEnabled();

    6.弹出对话框

    Alert alert = driver.switchTo().alert();

    alert.accept();  //确定

    alert.dismiss();  //取消

    alert.getText(); //获取文本

    7.表单

    WebElement approve = driver.findElement(By.id("approve"));

    approve.click();

    approve.submit();//只适合于表单的提交

    8.上传文件

    上传文件的元素操作:

    WebElement adFileUpload =driver.findElement(By.id("WAP-upload"));

    String filePath = "C: est\uploadfile\media_ads\test.jpg";

    adFileUpload.sendKeys(filePath);

    9.window和iframe的切换

    driver.switchTo().defaultContent();     //返回到最顶层的frame/iframe

    driver.switchTo().frame("leftFrame");    //切换到某个frame:

    driver.switchTo().window("windowName"); //切换到某个window 

    10.调用js

    Web driver对Java Script的调用是通过JavascriptExecutor来实现的,例如:

    JavascriptExecutor js = (JavascriptExecutor) driver;

    js.executeScript("JS脚本");

    11.超时设置

    WebDriver driver = new FirefoxDriver();

    driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);      //识别元素时的超时时间

    driver.manage().timeouts().pageLoadTimeout(10, TimeUnit.SECONDS);  //页面加载时的超时时间

    driver.manage().timeouts().setScriptTimeout(10, TimeUnit.SECONDS);  //异步脚本的超时时间

    • 关于frame:

    1. 如果网页存在iframe的话,传统的定位有时候找不到元素,需要切换frame;
    复制代码
            # 切换到leftFrame定位“测井设计”
            driver.switch_to_frame("leftFrame")
            driver.find_element_by_link_text(u"设计").click()
            # 切换到rightFrame定位“设计”(先回到主内容再次定位,否则二次定位认为嵌套)
            driver.switch_to_default_content()
            driver.switch_to_frame("rightFrame")
            driver.find_element_by_id("start").click()
    复制代码

           2.有些插件用的也是frame,如时间插件

    复制代码
           # 先定位到时间选择框,点击
            driver.find_element_by_id("logmin").click()
            #通过xpath定位frame
            frames = driver.find_element_by_xpath("/html/body/div[2]/iframe")
            #切换到frame
            driver.switch_to_frame(frames)
            # 选择2017-1-5,通过xpath定位,点击
            driver.find_element_by_xpath(
                "/html/body/div/div[3]/table/tbody/tr[2]/td[5]").click()
            # 最后切换回原来和右边的frame
            driver.switch_to_default_content()
            driver.switch_to_frame("rightFrame")
    复制代码
    • 关于下拉框

    1. 一般的下拉框可以通过二次定位来实现;
    #定位列表的一组数据
    names = driver.find_element_by_xpath("//*[@id='DataTables_Table_0']/tbody").find_elements_by_tag_name("input")

           2.如果下拉框的标签是option,可以用select;

      #选择select定位
            Select(driver.find_element_by_name("isImportant2")
                   ).select_by_visible_text(u"是")

           3.如果下拉框不是上面这种形式,而是调用其他地方生成的list,定位的时候,我目前没有非常好的法子。取了一个折中法子,使用键盘"上下键+enter"选择;

            #选择xpath定位到下拉列表,选择向下,点击回车,进行选择
            well = driver.find_element_by_xpath(
                "/html/body/span/span/span[2]/ul/li[1]")
            well.send_keys(Keys.DOWN)
            well.send_keys(Keys.ENTER)
    • 关于定位一列数据中的某一个;

    1. 定义了一个函数findname.py,获得含有关键字的列表名称,并返回list最大值;
    复制代码
    def fnn(names, keys):
        k = []
        for name in names:
            #循环获得属性为value的值
            s = name.get_attribute("value")
            #找到包含关键字keys的字符串
            if keys in s:
                k.append(s)
        newest = max(k)
        return newest
    复制代码
    复制代码
    #先定位到列表,在定位input,返回list
            names = driver.find_element_by_xpath(
                "//*[@id='DataTables_Table_0']/tbody").find_elements_by_tag_name("input")
            #关键字keys为zs
            name = findname.fnn(names, "zs")
            driver.find_element_by_link_text(name).click()
    复制代码
    • 字符串包含判断:关键字 in string;

    • 复制代码
      def fnn(names, keys):
          k = []
          for name in names:
              #循环获得属性为value的值
              s = name.get_attribute("value")
              #找到包含关键字keys的字符串
              if keys in s:
                  k.append(s)
          newest = max(k)
          return newest
  • 相关阅读:
    tctip demo页面>
    tctip demo页面>
    tctip demo页面>
    tctip demo页面>
    tctip demo页面>
    tctip demo页面>
    tctip demo页面>
    tctip demo页面>
    tctip demo页面>
    sql 随笔
  • 原文地址:https://www.cnblogs.com/klb561/p/9332843.html
Copyright © 2011-2022 走看看