selenium 如何处理table

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

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

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

Java代码  

  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方法为例,我们自己也可以创建这样功能的一个方法。

Java代码  

  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代码为例:

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>

示例代码如下:

Java代码  

  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(0, index));
  27. int cell = Integer.parseInt(tableCellAddress.substring(index+1));
  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()>0){
  40. cells = Row.findElements(By.tagName("th"));
  41. target = cells.get(cell);
  42. }
  43. if(Row.findElements(By.tagName("td")).size()>0){
  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));

	}

}

运行代码将输出

Java代码  

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

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

时间: 2024-11-23 00:39:53

selenium 如何处理table的相关文章

selenium 获取table数据

public class Table { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub WebDriver driver = ExplorerBase.IESetting(); String url = "http://zs.njust.edu.cn/newzs/news/zhxw/20140710151805.htm"; driver.m

python+selenium webdriver 如何处理table

Table对象是自动化测试中经常需要处理的对象.由于webdriver中没有专门的table类,所以我们需要简单的封装出一个易用易扩展的Table类来帮助简化代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59

selenium处理table表格

在UI自动化测试中经常会遇到表格的处理,下面是一点心得. 假设网页页面有一个表格,如何获取这个table的指定cell的值?你会说我们可以根据xpath定位到这个cell的行列,然后getText(),不错,但是页面的表格经常都不是固定的,如果这个表格增加或删除一些行列该如何处理? 我们可以把这个问题抽象出来,所有的html table不外乎是由 table 元素以及一个或多个 tr.th 或 td 元素组成,我们可以将行和列参数化,通过传入行和列的值获取返回的text信息. 这样我们可以根据输

Selenium Webdriver——Table类封装

WebTable.java import java.util.List; import org.openqa.selenium.By; import org.openqa.selenium.WebElement; public class WebTable { private WebElement webTable; public WebTable(WebElement webElement){ this.webTable = webElement; } //等到表格的行数 public int

Selenium之table操作

操作内容: 获取table总行数.总列数.获取某单元格的text值,删除一行[如果每行后边提供删除的按钮] HTML代码: <html><head><meta http-equiv="content-type" content="text/html;charset=utf-8"></head><body><script type="text/javascript"> func

Java+Selenium——如何处理日历控件——方法二

有些web产品,网页上有一些时间选择,然后支持按照不同时间段范围去筛选数据.网页上日历控件一般,是一个文本输入框,鼠标点击, 就会弹出日历界面,可以选择具体日期.这篇,就是介绍用selenium如何自动化脚本实现. 先看一个完全模仿手工操作的场景,点击输入框,点击下一个月,再点击一个日子. package rjcs; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar;

selenium 获取table中的元素。python

#获取table的行数rowCount = len(driver.find_elements_by_xpath('//*[@id="list-table"]/tbody/tr')) #获取第三列的每一行的值for i in range(2,rowCount): print driver.find_element_by_xpath('//*[@id="list-table"]/tbody/tr[%s]/td[3]'%(i)).text

python3 selenium 如何处理异常情况

使用场景: 1.元素只有在某一特定情况下才会出现 2.元素定位不到 使用方法: try: except exceptions.NoSuchElementException: 举例说明: 1 # _._ coding=utf-8 _._ 2 """ 3 :author: 花花测试 4 :time: 2017.05.08 5 :content: 处理元素定位的异常情况 6 """ 7 8 from selenium import webdriver

Java+Selenium——如何处理日历控件——方法一

如果遇到这样的日期控件,直接把当做正常的文本输入框,然后调用sendKeys()方法,直接传一个带格式的日期数据进入就可以. package rjcs; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.List; import java.util.Set; import org.openqa.selenium.interaction