[英]Parsing XML with Android and Java
我必須解析此XML https://i.imgur.com/GUAHB4t.jpg,以提取“ DetailPageURL”標記下的突出顯示的字符串。 我嘗試了一下,但是想法很混亂。 我正在使用Android SDK
import android.os.AsyncTask;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
public class ReflinkFetcher extends AsyncTask<String, Void, String> {
String refLink = null;
@Override
protected String doInBackground( String... url){
Document doc = openXML(url[0]);
Element rootElement = doc.getDocumentElement();
refLink = getString("DetailPageUrl", rootElement);
return refLink;
}
public String getRefLink(){
return refLink;
}
private Document openXML(String url) {
Document doc = null;
try {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
doc = db.parse(new URL(url).openStream());
} catch (SAXException e1) {
e1.printStackTrace();
} catch (ParserConfigurationException e1) {
e1.printStackTrace();
} catch (MalformedURLException e2) {
e2.printStackTrace();
} catch (IOException e3) {
e3.printStackTrace();
}
return doc;
}
private String getString(String tagName, Element element) {
NodeList list = element.getElementsByTagName("Items");
if (list != null && list.getLength() > 0) {
NodeList subList = list.item(0).getChildNodes(); //0=items
if (subList != null && subList.getLength() > 0) {
subList = subList.item(4).getChildNodes(); //4=item
if( subList != null && subList.getLength() >0 ) {
subList = subList.item(2).getChildNodes(); //2=DetailPageURL
if( subList != null && subList.getLength() >0 ) {
return subList.item(0).getNodeValue(); // Value??
}
}
}
}
return null;
}
}
最終的返回null將被執行。 我認為“ getString”方法也很差。 我該如何改善?
檢查這個漂亮的開源庫,您所需要做的就是漂亮的XML解析器 。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.