我有一个页面,里面有很多使用同一个类的文本。我想选择并存储同一个类的所有文本。这个是可能的吗?感谢所有的建议和评论!
我有这样的HTML代码:
<p class="foo">Some sample text</p>
<p class="foo">Some more sample text</p>我试过这样做:
<tr>
<td>storeText</td>
<td>//p[@class=foo']</td>
<td>var1</td>
</tr>我希望var1是:
Some sample text
Some more sample text或者,我是否需要设置一个while语句并分别收集每个语句?
本页讨论类似的练习,但使用Selenium for Python:Get the text from multiple elements with the same class in Selenium for Python?
发布于 2015-02-10 23:31:26
我没有尝试@bcar的答案,因为我不是javascript专家,我也不确定我能把答案放到IDE中。不过,我找到了另一条路。我发现文本存储在表中,所以我使用下面的代码来提取整个表(其中包括我需要的文本)。
<tr>
<td>storeText</td>
<td>//div/h2[text()="Elements and Performance Criteria"]/following::table</td>
<td>Content</td>
</tr>现在我必须想出如何用
因为这是纯文本。另一个堆叠溢出的问题!谢谢。
发布于 2015-01-11 03:15:27
//gather all p[class=foo]
List<WebElement> ele = driver.findElements(By.cssSelector("p.foo"));
Iterator<WebElement> iter = ele.iterator();
// initialize array, map, whatever
While(iter.hasNext()) {
// insert text into map
// print to log
// store in array
//whatever you need
var.add( iter.next().text() );
}发布于 2021-07-16 09:14:57
非常简单:只需循环遍历存储的元素。无论何时使用find_elements_by_class_name,它都会返回selenium web元素的列表。因此,您只需使用循环进行迭代,如下所示。
names = driver.find_elements_by_class_name("_xEcR")
for i in names:
print(i.text)https://stackoverflow.com/questions/27883117
复制相似问题