Selenium - 如何在Java中同时获取两个HTML节点的属性?

时间:2015-05-03 20:22:25

标签: java html selenium selenium-webdriver

我现在正在制作一个小时的节目,我完全糊涂了。所以这笔交易是因为我想成为一个蒸汽价格上涨的人。这是website

假设我要列出两个价格最高的商品名称及其价格。如果您查看html源代码,您将看到前两个找到的项目的名称如下:

id=result_0_name
id=result_1_name

但在结果0和结果1中,价格刚刚调用:“market_table_value”

我正试图打印出这样的:

System.out.println(driver.findElement(By.id("result_0_name"))).getAttribute("market_table_value");

但后来我意识到程序不会认出我想要“result0”的价格,也许它总会给我一个静态数字,因为市场价值没有唯一的数字。

很抱歉,如果我让你们感到困惑,但我真的希望你能理解我,因为我的思绪被炸毁了,我不知道怎么做:/

1 个答案:

答案 0 :(得分:0)

您想在此处使用xPath:

  • 获取项目名称://*[@id="result_0_name"]
  • 获取商品价格://*[@id="result_0"]/div[1]/span[1]/span

Java代码

public class Item {
     private String name;
     private String price;

     public Item(String name, String price) {
        this.name=name;
        this.price=price;
     }

     public String getName() {
        return name;
     }

     public String getPrice() {
        return price;
     }
}

/**
 *
 * Get item at position {@code position} or {@code null} if not found.
 *
 */
private Item getHighestItem(int position, WebDriver driver) {
   Item item=null;

   try {
      int index = position-1;
      String name = driver.findElement(By.xPath("//*[@id='result_" + index + "_name']")).getText();
      String price = driver.findElement(By.xPath("//*[@id='result_" + index + "']/div[1]/span[1]/span")).getText();

      item = new Item(name, price);
   } catch(NoSuchElementException nse) {
       // handle exception here...
   }

   return item;
}

示例用法

WebDriver driver = ...;
...
Item firstItem = getHighestItem(1, driver); // get Most expensive item 
Item secondItem = getHighestItem(2, driver); // get 2nd Most expensive item
...