![](/img/trans.png)
[英]Get data of html table from a website in android using Jsoup library,
[英]Receive table data from external website in Android using jSoup
在我的Android应用程序内部,我想从外部网站接收一些表格数据。
可以说,网站页面X的HTML内包含此表:
<table summary="Foo" border="0" bgcolor="#ffffff" cellpadding="0"> </table>
如何接收表格第二列(从上到下)的所有单元格内的字符串?
到目前为止,我已经做了以下工作:
我在AsyncTask中使用了以下代码:
ArrayList<String> list = new ArrayList<String>(); //table data
Document document = Jsoup.connect(url).get();
Elements nextTurns = document.select(":contains(Foo) td:eq(1)");
for (Element nextTurn : nextTurns) {
list.add(nextTurn.text());
}
在运行代码时,它似乎只是停在document.select
语句上,GC快要疯了。 经过很长时间后,它确实超越了document.select
语句,并且确实使大多数数据正确,但是它仍然从网站中随机提取其他元素。
我很确定这是完全错误的:
Elements nextTurns = document.select(":contains(Foo) td:eq(1)");
但是我不确定如何解决它,因为该表也缺少任何ID。 而且我发现此页面令人困惑。
如何修复select语句和/或for循环,以便它用第二个表列中的数据填充ArrayList?
编辑:通过删除contains(Foo)
它现在确实非常快,因此少了1个问题。 在将DOM元素遍历到表的第二列时,我仍然需要帮助,而无需占用网站的大量随机部分。
这是正确的选择,根据您的帖子进行猜测
document.select("table[summary=Foo] tr");
循环浏览上面的列表,并获得第二个<td>
,它位于列表的索引1。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.