selenium webdriver如何处理table

以前在selenium RC 里面有一个getTable方法,是得到一个单元格中的文本。其详细描述如下:

/** Gets the text from a cell of a table. The cellAddress syntax <span style="white-space: normal; background-color: #ffffff;">tableLocator.row.column</span> 

, where row and column start at 0. 

@param tableCellAddress a cell address, e.g. <span style="white-space: normal; background-color: #ffffff;">"foo.1.4"</span> 

@return the text from the specified cell 

*/  

String getTable(String tableCellAddress);  

就是传入一个参数,这个参数的格式必须是tableLocator.row.column,如"foo.1.4",foo用于得到table对象,1.4代表在table里第1行第4列。行、列从0开始。

在selenium
webdriver里,没有这样的方法,也就是说没有专门操作table的类。但我们可以自己封闭一个,这并不难。以上面的getTable方法为例,我们自己也可以创建这样功能的一个方法。

public String getCellText(By by,String tableCellAddress)  

我叫它getCellText,它有两个参数,第一个是By对象用于得到table对象,
tableCellAddress 如"1.4",代表在table里第1行第4列。行、列从0开始。

以下面html代码为例:


<html>  

    <head>  

        <title>Table</title>  

          

    </head>  

    <body>  

        <table border="1" id="myTable">  

            <tr>  

                <th>Heading(row 0 ,cell 0)</th>  

                <th>Another Heading(row 0 ,cell 1)</th>  

                <th>Another Heading(row 0 ,cell 2)</th>  

            </tr>  

            <tr>  

                <td>row 1, cell 0</td>  

                <td>row 1, cell 1</td>  

                <td>row 1, cell 2</td>  

            </tr>  

            <tr>  

                <td>row 2, cell 0</td>  

                <td>row 2, cell 1</td>  

                <td>row 2, cell 2</td>  

            </tr>  

        </table>  

    </body>  

</html>  
import java.util.List;  

import org.openqa.selenium.By;  

import org.openqa.selenium.NoSuchElementException;  

import org.openqa.selenium.WebDriver;  

import org.openqa.selenium.WebElement;  

import org.openqa.selenium.firefox.FirefoxDriver;  

  

public class Table {  

  

    /** 

     * @author gongjf 

     */  

    private WebDriver driver;  

    Table(WebDriver driver){  

        this.driver = driver;  

    }  

      

    /** 从一个table的单元格中得到文本值. 参数tableCellAddress的格式为 

    row.column, 行列从0开始. 

    @param by  用于得到table对象 

    @param tableCellAddress 一个单元格地址, 如. "1.4" 

    @return 从一个table的单元格中得到文本值 

    */  

    public String getCellText(By by,String tableCellAddress) {  

        //得到table元素对象  

        WebElement table = driver.findElement(by);  

        //对所要查找的单元格位置字符串进行分解,得到其对应行、列。  

        int index = tableCellAddress.trim().indexOf('.');  

        int row =  Integer.parseInt(tableCellAddress.substring(0, index));  

        int cell = Integer.parseInt(tableCellAddress.substring(index+1));  

        //得到table表中所有行对象,并得到所要查询的行对象。  

         List<WebElement> rows = table.findElements(By.tagName("tr"));  

         WebElement theRow = rows.get(row);  

         //调用getCell方法得到对应的列对象,然后得到要查询的文本。  

         String text = getCell(theRow, cell).getText();  

         return text;  

    }  

    private WebElement getCell(WebElement Row,int cell){  

         List<WebElement> cells;  

         WebElement target = null;  

         //列里面有"<th>"、"<td>"两种标签,所以分开处理。  

         if(Row.findElements(By.tagName("th")).size()>0){  

            cells = Row.findElements(By.tagName("th"));  

            target = cells.get(cell);  

         }  

         if(Row.findElements(By.tagName("td")).size()>0){  

            cells = Row.findElements(By.tagName("td"));  

            target = cells.get(cell);  

         }  

        return target;  

           

    }  
    public static void main(String[] args) {  

         WebDriver driver;  

         System.setProperty("webdriver.firefox.bin","D:\\Program Files\\Mozilla Firefox\\firefox.exe");    

         driver = new FirefoxDriver();  

         driver.get("file:///C:/Documents and Settings/Gongjf/桌面/selenium_test/table.html");  

      

         Table table = new Table(driver);  

         By by = By.id("myTable");  

         String address = "0.2";  

       

         System.out.println(table.getCellText(by, address));  

          

          

    }  

  

}  

运行代码将输出

Another Heading(row 0 ,cell 2)  

ps: 这里我只是以得到一个table中单元格的文本为例,但是从代码可以看出,对table的基本操作都有涉及到。有用到的同学可以自己包装一个完整的table类。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,761评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,953评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,998评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,248评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,130评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,145评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,550评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,236评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,510评论 1 291
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,601评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,376评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,247评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,613评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,911评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,191评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,532评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,739评论 2 335

推荐阅读更多精彩内容

  • Lua 5.1 参考手册 by Roberto Ierusalimschy, Luiz Henrique de F...
    苏黎九歌阅读 13,674评论 0 38
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,497评论 18 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,505评论 18 399
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,705评论 1 92
  • 01 薛洋不知道为什么会变成这样。 他死去了,确确实实死去了,但他的灵魂,现在却住在一只猫里。 周围的环境是他再熟...
    匪玉阅读 476评论 20 22