首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

selenium webdriver学习(十四)-如何避免table

2012-08-16 
selenium webdriver学习(十四)------------如何处理table以前在selenium RC 里面有一个getTable方法,是得

selenium webdriver学习(十四)------------如何处理table

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

?

/** Gets the text from a cell of a table. The cellAddress syntax tableLocator.row.column, where row and column start at 0.@param tableCellAddress a cell address, e.g. "foo.1.4"@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类。

热点排行