我对使用Selenium Remote Driver和Perl相当陌生。 我想做的是让Selenium使用部分匹配的文本找到页面上的所有元素。 然后将这些元素的全文存储到数组中。
我试过使用:
@elements = $driver->find_elements("//tbody/tr[td[2]/div/span[2][contains(text(),'matching text')]]")->get_text;
但是,这似乎不起作用。
我也试过: @elements = $driver->find_elements("//tbody/tr[td[2]/div/span[2][contains(text(),'matching text')]]");
这确实会用 Web 元素填充数组。
my @elements;
my @elementtext;
my $elementtext;
@elements = $driver->find_elements("//tbody/tr[td[2]/div/span[2][contains(text(),'matching text')]]");
foreach my $currentelement (@elements) {
$elementtext = $driver->find_element($currentelement)->get_text();
push @elementtext, $elementtext;
}
这会导致 perl 生成错误,因为 webdriver 找不到该元素。 关于我做错了什么以及如何解决它的任何想法? 我怀疑问题出在@elements数组的内容实际上不是 xpath 元素。
下面是一个 html 示例:
<td>
<div class='cellContent'><a href="/link/1">Atlanta</a></div>
</td>
<td>
<div class='cellContent'>City</div>
</td>
<td>
<div class='cellContent'>Georgia</div>
</td>
<td class='sort_column'>
<div class='cellContent'>USA</div>
</td>
</tr>
<tr>
<td>
<div class='cellContent'><a href="/travelers/1">Joe Passenger</a></div>
</td>
<td>
<div class='cellContent'> <span>NFL</span>
<span>matching text: Atlanta.Falcons.team</span>
</div>
</td>
我想将"匹配文本:Atlanta.Falcons.team"存储到数组中。
您可以使用此 XPaT 直接指向 span 标记。
//tbody/tr/td/div/span[contains(text(),'matching text')]