dom4j如何取得name相同的节点

比如:
XML code
 
     
GN declaration Wang 23 Li 24

我只想打印person的name和age,不想遍历!
------回答---------
------其他回答(3分)---------
不遍历? 那怎么能行 (⊙o⊙)
------其他回答(3分)---------
一次性获取所有name的节点
------其他回答(3分)---------

你指的是不想遍历person是吗?也就是想取得固定某个person的值或者前几个person的值??

Java code
 
    
DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance(); domFactory.setNamespaceAware(true); DocumentBuilder builder = domFactory.newDocumentBuilder(); InputStream is = new FileInputStream( "WebRoot/WEB-INF/某某某.xml"); Document doc = builder.parse(is); XPathFactory factory = XPathFactory.newInstance(); XPath xpath = factory.newXPath(); XPathExpression expr = xpath.compile("//person/name/text()|//person/age/text()"); Object result = expr.evaluate(doc, XPathConstants.NODESET); NodeList nodes = (NodeList) result; for (int i = 0; i < nodes.getLength(); i++) { System.out.println(nodes.item(i).getNodeValue()); }

不知道是不是你想要的那种。
------其他回答(3分)---------
当然能了。据说dom4j是这些比较好用的。但我没用过,呵呵。标题我仔细看,不好意思哈。
如果有时间的话LZ还是研究一下吧,我这比较忙。休息了一会我才来逛逛的。
GOOD LUCK......
------其他回答(3分)---------
Java code
 
    
package xml; import java.io.File; import java.io.IOException; import java.util.List; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class Dom4j { private SAXReader reader ; private Document document; private static String path = "c:/bbc.xml"; //查找 public Dom4j(String str) throws DocumentException { reader = new SAXReader(); document = reader.read(new File(str)); } //查找指定节点 public void getInfo() { Element root = document.getRootElement(); List list = root.elements(); //Element e = root.element("person"); for(int i=0;i
------其他回答(3分)---------
等不遍历的
------其他回答(22分)---------
这样行吗?
Java code
 
    
Element root = document.getRootElement(); QName qname = new QName("person"); List list = root.elements(qname); for(int i= 0;i

------回答---------

------其他回答(3分)---------

不遍历? 那怎么能行 (⊙o⊙)
------其他回答(3分)---------

一次性获取所有name的节点
------其他回答(3分)---------

你指的是不想遍历person是吗?也就是想取得固定某个person的值或者前几个person的值??
Java code
 
    
DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance(); domFactory.setNamespaceAware(true); DocumentBuilder builder = domFactory.newDocumentBuilder(); InputStream is = new FileInputStream( "WebRoot/WEB-INF/某某某.xml"); Document doc = builder.parse(is); XPathFactory factory = XPathFactory.newInstance(); XPath xpath = factory.newXPath(); XPathExpression expr = xpath.compile("//person/name/text()|//person/age/text()"); Object result = expr.evaluate(doc, XPathConstants.NODESET); NodeList nodes = (NodeList) result; for (int i = 0; i < nodes.getLength(); i++) { System.out.println(nodes.item(i).getNodeValue()); }

不知道是不是你想要的那种。
------其他回答(3分)---------

当然能了。据说dom4j是这些比较好用的。但我没用过,呵呵。标题我仔细看,不好意思哈。
如果有时间的话LZ还是研究一下吧,我这比较忙。休息了一会我才来逛逛的。
GOOD LUCK......
------其他回答(3分)---------

Java code
 
    
package xml; import java.io.File; import java.io.IOException; import java.util.List; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class Dom4j { private SAXReader reader ; private Document document; private static String path = "c:/bbc.xml"; //查找 public Dom4j(String str) throws DocumentException { reader = new SAXReader(); document = reader.read(new File(str)); } //查找指定节点 public void getInfo() { Element root = document.getRootElement(); List list = root.elements(); //Element e = root.element("person"); for(int i=0;i
------其他回答(3分)---------

等不遍历的
------其他回答(22分)---------

这样行吗?
Java code
 
    
Element root = document.getRootElement(); QName qname = new QName("person"); List list = root.elements(qname); for(int i= 0;i



你可能感兴趣的:(java)