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类。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这个网站的滑块验证码比较复杂,需要先进行一些处理才能通过滑动验证。以下是一个基本的思路: 1. 打开网站,点击进入采购公告页面。 2. 点击“全部”按钮,切换到全部采购公告页面。 3. 首先尝试通过点击“查询”按钮绕过滑块验证。 4. 若滑块验证未通过,则进行滑动验证。 5. 滑动验证后,再次点击“查询”按钮,即可获取采购公告列表。 具体实现可以参考以下代码: ```python from selenium import webdriver from selenium.webdriver.common.action_chains import ActionChains from selenium.webdriver.common.by import By from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.support import expected_conditions as EC import time driver = webdriver.Chrome() driver.get('http://www.ccgp-liaoning.gov.cn/portalindex.do?method=goPubInfoList') # 点击进入采购公告页面 driver.find_element_by_link_text('采购公告').click() # 点击切换到全部采购公告页面 driver.find_element_by_link_text('全部').click() # 尝试通过点击“查询”按钮绕过滑块验证 driver.find_element_by_id('query').click() # 判断是否出现滑块验证 if '请完成验证' in driver.page_source: # 定位滑块元素 slider = WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.ID, 'validate'))) slider_knob = slider.find_element_by_class_name('ui-slider-handle') # 计算需要滑动的距离 slider_width = slider.size['width'] knob_width = slider_knob.size['width'] distance = slider_width - knob_width # 模拟滑动操作 ActionChains(driver).click_and_hold(slider_knob).move_by_offset(distance, 0).release().perform() # 等待滑块验证完成 time.sleep(2) # 再次尝试点击“查询”按钮 driver.find_element_by_id('query').click() # 获取采购公告列表 table = WebDriverWait(driver, 10).until(EC.presence_of_element_located((By.ID, 'resultslist'))) rows = table.find_elements_by_tag_name('tr') for row in rows[1:]: cells = row.find_elements_by_tag_name('td') print(cells[1].text) ``` 需要注意的是,滑块验证的具体实现方式因网站而异,以上代码仅供参考,具体实现需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值