qi_ling2005  http://jarvi.iteye.com/blog/1477837

andyguo  http://blog.csdn.net/gzh0222/article/details/7568490

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

  1. /** Gets the text from a cell of a table. The cellAddress syntax <span style="white-space: normal; #ffffff;">tableLocator.row.column</span>
  2. , where row and column start at 0.
  3. @param tableCellAddress a cell address, e.g. <span style="white-space: normal; #ffffff;">"foo.1.4"</span>
  4. @return the text from the specified cell
  5. */
  6. String getTable(String tableCellAddress);
/** 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方法为例,我们自己也可以创建这样功能的一个方法。

  1. public String getCellText(By by,String tableCellAddress)
public String getCellText(By by,String tableCellAddress)

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

以下面html代码为例:

  1. <html>
  2. <head>
  3. <title>Table</title>
  4. </head>
  5. <body>
  6. <table border="1" id="myTable">
  7. <tr>
  8. <th>Heading(row 0 ,cell 0)</th>
  9. <th>Another Heading(row 0 ,cell 1)</th>
  10. <th>Another Heading(row 0 ,cell 2)</th>
  11. </tr>
  12. <tr>
  13. <td>row 1, cell 0</td>
  14. <td>row 1, cell 1</td>
  15. <td>row 1, cell 2</td>
  16. </tr>
  17. <tr>
  18. <td>row 2, cell 0</td>
  19. <td>row 2, cell 1</td>
  20. <td>row 2, cell 2</td>
  21. </tr>
  22. </table>
  23. </body>
  24. </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>

示例代码如下:

  1. import java.util.List;
  2. import org.openqa.selenium.By;
  3. import org.openqa.selenium.NoSuchElementException;
  4. import org.openqa.selenium.WebDriver;
  5. import org.openqa.selenium.WebElement;
  6. import org.openqa.selenium.firefox.FirefoxDriver;
  7. public class Table {
  8. /**
  9. * @author gongjf
  10. */
  11. private WebDriver driver;
  12. Table(WebDriver driver){
  13. this.driver = driver;
  14. }
  15. /** 从一个table的单元格中得到文本值. 参数tableCellAddress的格式为
  16. row.column, 行列从0开始.
  17. @param by  用于得到table对象
  18. @param tableCellAddress 一个单元格地址, 如. "1.4"
  19. @return 从一个table的单元格中得到文本值
  20. */
  21. public String getCellText(By by,String tableCellAddress) {
  22. //得到table元素对象
  23. WebElement table = driver.findElement(by);
  24. //对所要查找的单元格位置字符串进行分解,得到其对应行、列。
  25. int index = tableCellAddress.trim().indexOf('.');
  26. int row =  Integer.parseInt(tableCellAddress.substring(, index));
  27. int cell = Integer.parseInt(tableCellAddress.substring(index+));
  28. //得到table表中所有行对象,并得到所要查询的行对象。
  29. List<WebElement> rows = table.findElements(By.tagName("tr"));
  30. WebElement theRow = rows.get(row);
  31. //调用getCell方法得到对应的列对象,然后得到要查询的文本。
  32. String text = getCell(theRow, cell).getText();
  33. return text;
  34. }
  35. private WebElement getCell(WebElement Row,int cell){
  36. List<WebElement> cells;
  37. WebElement target = null;
  38. //列里面有"<th>"、"<td>"两种标签,所以分开处理。
  39. if(Row.findElements(By.tagName("th")).size()>){
  40. cells = Row.findElements(By.tagName("th"));
  41. target = cells.get(cell);
  42. }
  43. if(Row.findElements(By.tagName("td")).size()>){
  44. cells = Row.findElements(By.tagName("td"));
  45. target = cells.get(cell);
  46. }
  47. return target;
  48. }
  49. public static void main(String[] args) {
  50. WebDriver driver;
  51. System.setProperty("webdriver.firefox.bin","D:\\Program Files\\Mozilla Firefox\\firefox.exe");
  52. driver = new FirefoxDriver();
  53. driver.get("file:///C:/Documents and Settings/Gongjf/桌面/selenium_test/table.html");
  54. Table table = new Table(driver);
  55. By by = By.id("myTable");
  56. String address = "0.2";
  57. System.out.println(table.getCellText(by, address));
  58. }
  59. }
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)); } }

运行代码将输出

  1. Another Heading(row  ,cell )
Another Heading(row 0 ,cell 2)

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

selenium 如何处理table的更多相关文章

  1. java selenium 题目二 如何处理Table

    如果操作Table.  例如我有一个table.  table 的列的顺序是会变化的, 行数也是会变化的. 问题: 如果通过名字获取到年龄 HTML 源代码 <html> <body ...

  2. [唐胡璐]Selenium技巧- 如何处理Table

    由于webdriver中没有专门的table类,所以我们需要简单的封装出一个易用易扩展的Table类来帮助简化代码。 以下是我之前用C#语言来实现的一个简单的封装: 只是一个大概的思路,有些具体实现就 ...

  3. Selenium之table操作

    操作内容: 获取table总行数.总列数.获取某单元格的text值,删除一行[如果每行后边提供删除的按钮] HTML代码: <html><head><meta http- ...

  4. Selenium Webdriver——Table类封装

    WebTable.java import java.util.List; import org.openqa.selenium.By; import org.openqa.selenium.WebEl ...

  5. selenium处理table表格

    在UI自动化测试中经常会遇到表格的处理,下面是一点心得. 假设网页页面有一个表格,如何获取这个table的指定cell的值?你会说我们可以根据xpath定位到这个cell的行列,然后getText() ...

  6. python3 selenium 如何处理异常情况

    使用场景: 1.元素只有在某一特定情况下才会出现 2.元素定位不到 使用方法: try: except exceptions.NoSuchElementException: 举例说明: # _._ c ...

  7. 在MAC下使用Robotframework+Selenium2【第二枪】如何处理Table点击指定记录

    1.通过关键字Get Matching Xpath Count获取table中的记录 2.遍历Table所有记录 3.判断记录是否符合条件,做点击操作

  8. selenium 获取table数据

    public class Table { /** * @param args */ public static void main(String[] args) { // TODO Auto-gene ...

  9. selenium如何处理H5视频

    selenium处理H5视频主要使用的是javascript,javascript函数有内置的对象叫arguments,arguments包含了调用的参数组,[0]代表取第一个值. currentSr ...

随机推荐

  1. sql分割字符串

    DECLARE @str NVARCHAR(MAX); SET @str = 'aa|bb|cc|dd'; ) SET @str += '|' BEGIN SET @n = LEFT(@str, CH ...

  2. iis下php 500错误

      很不想用iis,然而客户不想增加机器,只好按客户的意思了.可是没想到发送短信以在本地 机器上是好的,在iis下直接500.   一开始以为是防火墙问题,后来检查了一下没有,再后来换了一个短信接口, ...

  3. hadoop 大数据 介绍

    1.Hadoop是一个大家族,是一个开源的生态系统,是一个分布式运行系统,是基于Java编程语言的架构.不过它最高明的技术还是HDFS和MapReduce,使得它可以分布式处理海量数据. 2.HDFS ...

  4. Base64与MD5的区别

    Base64和MD5都可用于做信息的简单加密,两者的简单差别如下: Base64 可逆性. 可以将图片等二进制文件转换为文本文件. 可以把非ASCII字符的数据转换成ASCII字符,避免不可见字符. ...

  5. python抓取今日头条

    # 直接上代码,抓取关键词搜索结果的json数据# coding:utf-8 import requests import json url = 'http://www.toutiao.com/sea ...

  6. WCF安全:通过 扩展实现用户名密码认证

    在webSservice时代,可以通过SOAPHEADER的方式很容易将用户名.密码附加到SOAP header消息头上,用户客户端对调用客户端身份的验证.在WCF 时代,也可以通过Operation ...

  7. 【html5】html5 本地存储

    最近一直在学习 html5,为了后期的移动项目进行知识储备.html5 相对于 html4 新增加了一些有趣的标签.属性和方法,今天主要介绍下 html5 的本地存储. 在客户端存储数据 html5 ...

  8. LibGDX skins

    https://github.com/czyzby/gdx-skins ———————————————————————————————————————————— LibGDX comes with a ...

  9. poj 1723 中位数

    最近在看一些中位数的东西,然后顺便也看了些题目.poj 1723不仅要求到水平位置的最短距离和,还要求水平都相邻的排成一排的最短距离和,即士兵都站成一列. 到y轴的距离好办,按y轴坐标排序,求中位数, ...

  10. placeholder兼容IE8解决方案

    1.原因:placeholder是h5的新属性,IE10以前的浏览器(8.9)不支持此属性.   2.解决方法:jQuery三方插件  jquery-placeholder 3.快速开始: <! ...