我需要解析从 http 请求获得的 XML 的特定部分,但我不知道该怎么做!
我返回了以下 XML 结构:
<categorias type="array">
<categoria>
<nome>
Alimentação
</nome>
<idcategoria>
5
</idcategoria>
<subcategorias>
<subcategoria>
<nome>
Todos
</nome>
<id>
5
</id>
</subcategoria>
</subcategorias>
</categoria>
</categorias>
我需要解析 subcategorias 标记内的数据,因为使用我现在拥有的代码,我只能从根标记类别中获取上部标记,例如 nome 和 idcategoria。
我在 for 循环中创建了一个 NodeList,但它返回了 Document 中的所有子类别标签。而且我只需要获取唯一类别标签中的那些。这是我现在拥有的代码:
menuItems = new ArrayList<HashMap<String, String>>();
XMLParser parser = new XMLParser();
String xml = parser.getXmlFromUrl(URL); // getting XML
Document doc = parser.getDomElement(xml); // getting DOM element
NodeList nl = doc.getElementsByTagName(KEY_ITEM);
// looping through all item nodes <item>
for (int i = 0; i < nl.getLength(); i++) {
// creating new HashMap
HashMap<String, String> map = new HashMap<String, String>();
Element e = (Element) nl.item(i);
// adding each child node to HashMap key => value
map.put(KEY_ID, parser.getValue(e, KEY_ID));
map.put(KEY_NAME, parser.getValue(e, KEY_NAME));
// adding HashList to ArrayList
menuItems.add(map);
}
有人可以帮我解决这个问题吗!?
提前致谢!