2011-06-17 148 views
-1

的指数我有HTML代码如下所示:获取html元素

String html = "<html><head><style type=\"text/css\"></style></head><body><div style=\"font-family:times new roman,new york,times,serif;font-size:14pt\">first text<br><div><br></div><div style=\"font-family: times new roman,new york,times,serif; font-size: 14pt;\"><br><div style=\"font-family: times new roman,new york,times,serif; font-size: 12pt;\"><font size=\"2\" face=\"Tahoma\"><hr size=\"1\"><b><span style=\"font-weight: bold;\">one:</span></b> second text<br><b><span style=\"font-weight: bold;\">two:</span></b> third text<br><b><span style=\"font-weight: bold;\">three:</span></b> fourth text<br><b><span style=\"font-weight: bold;\">five:</span></b> fifth text<br></font><br>"; 

,我想知道如何获得第三DIV的指数?

回答

0

DOM/XML解析器可能更好,这取决于你需要做什么。但简单的方法是:

int index = -1; 
for(int i=0; i < 3; i++){ 
    index = html.indexOf("<div",index + 1); 
    if(index == -1) 
     throw new Exception(); 
} 
4

我会用一个DOM解析器来做到这一点。如果你有正确的XML(有效的XHTML)内容,你也可以使用XML解析器。

而且要选择哪个库,this question可以帮助您。

更新:据我所知,您的内容是无效的XML。所以this question可能对你更好。

+0

是否有像我想要做的事情的样本? –

+0

哪个?有效或无效部分? –

+0

你在说什么是无效部分? –