假设我有以下 XML 文件:
<?xml version="1.0" encoding="utf-8"?>
<venues>
<group type="Nearby">
<venue>
<id>222307</id>
<name>Union Chapel</name>
<primarycategory>
<id>78967</id>
<fullpathname>Arts & Entertainment:Music Venue</fullpathname>
<nodename>Music Venue</nodename>
<iconurl>http://foursquare.com/img/categories/arts_entertainment/musicvenue.png</iconurl>
</primarycategory>
<address>Compton Ave</address>
<city>Islington</city>
<state>Greater London</state>
<zip>N1 2XD</zip>
<verified>false</verified>
<geolat>51.5439732</geolat>
<geolong>-0.1020908</geolong>
<stats>
<herenow>0</herenow>
</stats>
<phone>02073594019</phone>
<distance>33</distance>
</venue>
................
我的代码如下:
XPathFactory factory = XPathFactory.newInstance();
XPath xpath = factory.newXPath();
XPathExpression expr = xpath.compile("//venue/*");
Object result = expr.evaluate(document, XPathConstants.NODESET);
NodeList nodes = (NodeList) result;
//System.out.println(nodes.getLength());
Venue ven = new Venue();
for (int i = 0; i < nodes.getLength(); i++) {
String nodeName = nodes.item(i).getNodeName();
String nodeValue = nodes.item(i).getNodeValue();
if (nodeName.equals("id")){
ven = new Venue();
if (nodeValue != null)
ven.id = Integer.parseInt(nodeValue);
System.out.println(ven.id);
}
if (nodeName.equals("name")){
ven.name = nodeValue;
System.out.println(ven.name);
}
if (nodeName.equals("address")){
ven.address = nodeValue;
System.out.println(ven.address);
}
我怎样才能在一个 for 循环中完成所有这些以提高效率?否则,对于我想要提取的 xml 中的每个属性,我需要为它们中的每一个创建一个 for 循环
最佳答案
如果您使用它作为您的 xpath:
//venue/*
您将获得 venue 的所有子节点。然后您可以迭代它并在节点名称上做一个大的 if else 并根据需要分配它们。
像这样:
XPathFactory factory = XPathFactory.newInstance();
XPath xpath = factory.newXPath();
XPathExpression expr = xpath.compile("//venue/*");
Object result = expr.evaluate(document, XPathConstants.NODESET);
NodeList nodes = (NodeList) result;
for (int i = 0; i < nodes.getLength(); i++) {
Node node = nodes.item( i );
String nodeName = node.getNodeName();
String nodeValue = node.getChildNodes().item( 0 ).getNodeValue();
if( nodeName.equals( "name" ) ) {
name = nodeValue;
}
else if( nodeName.equals( "address" ) ) {
address = nodeValue;
} // ... the rest goes here
}
如果您不想遍历所有子元素,您可以这样做:
XPathExpression expr = xpath.compile( "//venue" );
Object result = expr.evaluate( document, XPathConstants.NODESET );
NodeList nodes = (NodeList)result;
for( int i = 0; i < nodes.getLength(); i++ ) {
Node node = nodes.item( i );
NodeList venueChildNodes = node.getChildNodes();
String id = venueChildNodes.item( 1 ).getChildNodes().item( 0 ).getNodeValue();
System.out.println( "id: " + id );
String name = venueChildNodes.item( 3 ).getChildNodes().item( 0 ).getNodeValue();
System.out.println( "name: " + name );
String address = venueChildNodes.item( 7 ).getChildNodes().item( 0 ).getNodeValue();
System.out.println( "address: " + address );
}
在其中获取所有 field 节点,然后映射它的子节点。但是,这种方法需要相当一致的 xml 结构。不过,这样的事情对我来说似乎是最安全的:
XPathExpression expr = xpath.compile( "//venue" );
Object result = expr.evaluate( document, XPathConstants.NODESET );
NodeList nodes = (NodeList)result;
for( int i = 0; i < nodes.getLength(); i++ ) {
Node node = nodes.item( i );
NodeList venueChildNodes = node.getChildNodes();
String address = null;
String name = null;
for( int j = 0; j < venueChildNodes.getLength(); j++ ) {
Node item = venueChildNodes.item( j );
String nodeName = item.getNodeName();
if ( nodeName.equals( "address" ) ) {
address = item.getChildNodes().item( 0 ).getNodeValue();
}
if ( nodeName.equals( "name" ) ) {
name = item.getChildNodes().item( 0 ).getNodeValue();
}
}
System.out.println( "address: " + address );
System.out.println( "name: " + name );
}
关于java - 在 Java 中使用 XPath 解析 XML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4082690/