XML
<?xml version="1.0"?>
<Employees>
<Employee emplid="1111" type="admin">
<firstname>John</firstname>
<lastname>Watson</lastname>
<age>30</age>
<email>johnwatson@sh.com</email>
</Employee>
<Employee emplid="2222" type="admin">
<firstname>Sherlock</firstname>
<lastname>Homes</lastname>
<age>32</age>
<email>sherlock@sh.com</email>
</Employee>
<Employee emplid="3333" type="user">
<firstname>Jim</firstname>
<lastname>Moriarty</lastname>
<age>52</age>
<email>jim@sh.com</email>
</Employee>
<Employee emplid="4444" type="user">
<firstname>Mycroft</firstname>
<lastname>Holmes</lastname>
<age>41</age>
<email>mycroft@sh.com</email>
</Employee>
</Employees>
代码
FileInputStream file = new FileInputStream(new File("/Users/Desktop/employees.xml"));
DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = builderFactory.newDocumentBuilder();
Document xmlDocument = builder.parse(file);
XPath xPath = XPathFactory.newInstance().newXPath();
System.out.println("*************************");
String expression = "/Employees/Employee/firstname";
System.out.println(expression);
NodeList nodeList = (NodeList) xPath.compile(expression).evaluate(xmlDocument, XPathConstants.NODESET);
for (int i = 0; i < nodeList.getLength(); i++) {
System.out.println(nodeList.item(i).getFirstChild().getNodeValue());
}
通过使用上面的代码,我设法获取了John,Sherlock,Jim,Mycroft
。如果我想获得emplid="1111" type="admin" John,emplid="2222" type="admin" Sherlock,emplid="3333" type="user" Jim,emplid="4444" type="user" Mycroft
,该怎么办?任何建议或参考链接都非常感谢。
答案 0 :(得分:1)
你的XPath应该是/ Employees / Employee / @ emplid 要学习XPath,请遵循本教程
答案 1 :(得分:1)
看看@ API:
String expression = "/Employees/Employee";
NodeList nodeList = (NodeList) xPath.compile(expression).evaluate(xmlDocument, XPathConstants.NODESET);
for (int i = 0; i < nodeList.getLength(); i++) {
Node employeeNode = nodeList.item(i);
String emplId = employeeNode.getAttributes().getNamedItem("emplid").getNodeValue();
}
(http://docs.oracle.com/javase/6/docs/api/org/w3c/dom/Node.html#getAttributes())
答案 2 :(得分:1)
您需要创建三个单独的xpath表达式。
/Employees/Employee[@emplid]
/Employees/Employee[@type]
Ans第三个是您使用的那个..
如果您想了解有关xpath的更多信息,请here is a good link.