WebDriver表格定位-----遍历表格的全部单元格


  1. import org.openqa.selenium.By;  
  2. import org.openqa.selenium.WebDriver;  
  3. import org.openqa.selenium.WebElement;  
  4. import org.testng.annotations.Test;  
  5.   
  6. public class LocateTable {  
  7.     public WebDriver driver;  
  8.   @Test  
  9.   public void LocateTableTest() {  
  10.       WebElement table = driver.findElement(By.id("table"));  
  11.       List rows = table.findElements(By.tagName("tr"));  
  12. //    assertEquals(5,rows.size());  
  13.       for(WebElement row:rows){  
  14.           List cols= row.findElements(By.tagName("td"));  
  15.           for(WebElement col:cols){  
  16.               System.out.println(col.getText()+"\t");               
  17.           }  
  18.           System.out.println("");  
  19.       }  
  20.   }  
  21. }  

代码逻辑:

(1)先定位表格的页面元素对象;

[java]  view plain  copy
  1. WebElement table = driver.findElement(By.id("table"));  
(2)在表格页面元素对象中,把所有的tr元素对象存储到list对象中(即把表格中每行的对象存储到一个list中)

[java]  view plain  copy
  1. List rows = table.findElements(By.tagName("tr"));  

(3)使用for循环方式,先将表格行对象从rows对象中取出,使用findElements函数将表格行对象中的所有单元格对象存储到名为cols的List对象中,然后再次使用for循环把每行的单元格文本遍历输出。

[java]  view plain  copy
  1. List rows = table.findElements(By.tagName("tr"));  
  2. for(WebElement row:rows){  
  3.  List cols= row.findElements(By.tagName("td"));  
  4.  for(WebElement col:cols){  
  5.   System.out.println(col.getText()+"\t");               
  6.  }  
  7.  System.out.println("");  
  8. }  

col.getText()表示获取单元格的文本内容


  1. "code" class="java"># 定位显示表格的第二行第二列单元格  
  2. XPath表达式实例:  
  3.  //*[@id='table']/tbody/tr[2]/td[2]  
  4.  Java实例代码:  
  5.  WebElement cell = driver.findElement(By.xpath("//*[@id='table']/tbody/tr[2]/td[2]"));  
  6.   
  7.  表达式中的tr[2]表示第二行,td[2]表示第二列,组合起来就是第二行第二列单元格  
http://toolsqa.com/selenium-webdriver/handle-dynamic-webtables-in-selenium-webdriver/

你可能感兴趣的:(Web自动化测试,JAVA)