Selenium 2 и html-таблицы

Просто интересно, есть ли лучший способ получить значения из таблицы в селене 2. В настоящее время я использую 2 цикла for, которые я перебираю по каждому TR, и внутри каждого TR я перебираю все TD. так, например, если у меня есть строка таблицы с 10 столбцами, я зацикливаюсь 10 раз и вытаскиваю текстовое значение. Это кажется мне неуклюжим.

Моя таблица Rows выглядит так

<tr id="cTestData" class="odd">
<td class="date_activated">08/31/2011</td>
<td class="date_redeemed"> Not redeemed * </td>
<td class="expiration_date">09/01/2011</td>
<td class="product"> State of Maine </td>
<td class="value">$1.00</td>
<td class="store"> &ndash; &ndash; &ndash; </td>
<td class="offer_details">
</tr>

Я думаю, что я должен иметь возможность сказать для каждой строки таблицы, чтобы получить элемент TD с классом = date_activated и вернуть дату. Я пробовал несколько вещей, но ничего не работало на основе имени класса TD = foo

Если это поможет, мой фактический код

for(WebElement trElement : tr_collection)
        {
            List<WebElement> td_collection=trElement.findElements(By.xpath("td"));
            System.out.println("NUMBER OF COLUMNS="+td_collection.size());
            col_num=1;          
            HashMap actInfo = new HashMap();  // new hashmap for each line inthe result set

            if(!td_collection.isEmpty() && td_collection.size() != 1 ){  
                for(WebElement tdElement : td_collection)
                {
                        System.out.println("Node Name=== " + tdElement.getAttribute("class")); 
                        System.out.println("Node Value=== " + tdElement.getText());
                        actInfo.put(tdElement.getAttribute("class"), tdElement.getText());
                    col_num++;
                }
                masterMap.add(actInfo);
            } // end if

            row_num++;
        }

person ducati1212    schedule 21.09.2011    source источник


Ответы (3)


Попробуй это:

driver.findElements(By.xpath("//tr[@class='foo']/td[@class='date_activated']"))

Это вернет все элементы TD с классом date_activated с родительской строкой с классом foo. Затем вы можете просмотреть элементы и использовать getText для получения дат. Это работает из корня страницы.

Если вы хотите сделать это для каждого элемента TR, попробуйте:

trElement.findElement(By.xpath("./td[@class='date_activated']")).getText()
person prestomanifesto    schedule 21.09.2011
comment
Обычно я стараюсь избегать xpath, но это работало нормально, пока я не нашел более приятное решение. Спасибо - person ducati1212; 23.09.2011

Мне было проще работать с таблицами как с таблицей. Вам все равно придется использовать XPath, но он ограничен таблицей.

IWebElement table = driver.FindElement(By.Id("TableId")); //Get Table 
List<IWebElement> Rows = new List<IWebElement>(table.FindElements(By.XPath(".//tbody/tr")));
List<List<IWebElement>> table_element = new List<List<IWebElement>>(); 
for (int k = 0; k < Rows.Count; k++)
{                 
    table_element.Add(new List<IWebElement>(Rows[k].FindElements(By.XPath("./td")))); //Get all Elements from Rows
}

for (int k = 0; k < table_element[0].Count; k++)
{
    if (table_element[0][k].Text == "08/31/2011")
    {
        table_element[0][k].Click();               
    }            
 }
person Chuck Brown    schedule 03.07.2014

Если вы предпочитаете использовать селектор css, попробуйте:

List<WebElement> myTds = driver.findElements(By.cssSelector("#tableId .date_activated"));

Обратите внимание на пробел в "#tableId .date_activated".

Это выберет все элементы с классом date_activated в таблице с идентификатором tableId. Вам все равно нужно будет перебрать этот список, чтобы получить текст каждой из ваших ячеек.

Может быть достаточно более простого селектора:

driver.findElements(By.cssSelector(".date_activated"))

Это позволит найти все элементы класса date_activated на вашей странице.

person Izabela    schedule 28.01.2014