如何解决使用 DOM 解析器根据父节点属性检索子节点值
我的 XML 内容如下
<PARENT1 ATTR="FILE1">
<TITLE>test1.pdf</TITLE>
</PARENT1>
<PARENT2 ATTR="FILE2">
<TITLE>test2.pdf</TITLE>
</PARENT2>
我想通过将映射键添加为父属性值并将映射值添加为子节点值来在 Java 中创建哈希映射。 示例:
map.put("FILE1","test1.pdf");
map.put("FILE2","test2.pdf");
我知道要获取所有子节点列表,但我不知道如何根据父节点属性或父节点获取子节点值。 如何使用 DOM 或 SAX 解析器在 Java 中实现这一点。
非常感谢任何帮助。
问候,
滕杜尔卡
解决方法
如果 XML 文件不是很大,我建议使用 JDOM 而不是默认的 DOM 解析器,因为它对用户更加友好。
这是一个可以做您想做的事情的示例,但您需要自己进行错误检查等。
public class XmlParser {
private static final String xml = "<parents><parent name=\"name1\"><title>title1</title></parent><parent name=\"name2\"><title>title2</title></parent></parents>";
public static final void main(String [] args) throws ParserConfigurationException,SAXException,IOException {
DocumentBuilder builder = DocumentBuilderFactory.newInstance().newDocumentBuilder();
Document doc = builder.parse(new InputSource(new StringReader(xml)));
Node parents = doc.getChildNodes().item(0);
Map<String,String> dataMap = new HashMap<>();
for (int i = 0; i < parents.getChildNodes().getLength(); i++) {
Node parent = parents.getChildNodes().item(i);
String name = parent.getAttributes().getNamedItem("name").getNodeValue();
String title = parent.getChildNodes().item(0).getTextContent();
dataMap.put(name,title);
}
System.out.println(dataMap);
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。