【发布时间】:2018-01-04 14:20:18
【问题描述】:
我必须解析这个 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”方法也很差。我该如何改进它?
【问题讨论】:
-
我推荐你阅读 Retrofit and Simple XML Converter for it
-
这个通用问题之前已经回答过很多次 - 例如。 stackoverflow.com/questions/340787/… 那里给出的解决方案使用 XPath,我认为这将是解决这个特定问题的理想解决方案。