【发布时间】:2013-11-26 05:03:11
【问题描述】:
我正在尝试为元素“way”下的每个“nd”提取“ref”信息。我尝试使用常规的 java xml 解析器和 XPath,但仍然无法弄清楚如何检索多个子节点。
<?xml version='1.0' encoding='UTF-8'?>
<osm version="0.6" generator="Osmosis 0.43.1">
<node id="95946773" version="3" timestamp="2009-11-14T15:52:46Z" uid="17427" user="dysteleologist" changeset="3114170" lat="26.2870135" lon="-80.2120936"/>
<node id="95946776" version="3" timestamp="2010-10-23T15:07:03Z" uid="207745" user="NE2" changeset="6146275" lat="26.2870058" lon="-80.2128489"/>
<way id="226137459" version="1" timestamp="2013-06-17T20:19:27Z" uid="1119200" user="wagn" changeset="16595491">
<nd ref="2349898722"/>
<nd ref="2349898723"/>
<nd ref="2349898724"/>
<nd ref="2349898725"/>
<nd ref="2349898726"/>
<nd ref="2349898730"/>
<nd ref="2349898727"/>
<nd ref="2349898728"/>
<nd ref="2349898729"/>
<nd ref="2349898722"/>
<tag k="building" v="house"/>
</way>
</osm>
我提取“方式”元素的代码。
NodeList wList = doc.getElementsByTagName("way");
for (int temp = 0; temp < wList.getLength(); temp++) {
Node wNode = wList.item(temp);
if (wNode.getNodeType() == Node.ELEMENT_NODE) {
Element wElement = (Element) wNode;
output_str = "";
output_str += wElement.getAttribute("id")+ " ";
System.out.println(wElement.getElementsByTagName("nd").item(0).getAttribute("ref"));
如果我将最后一个打印行更改为下面
System.out.println(wElement.getElementsByTagName("nd").item(0).getNodeName());
它实际上打印出“nd”作为节点名称,但我无法获取节点的属性。
在 javascript 中,它的工作方式如下,但这种语法在 Java 中不起作用。
System.out.println(wElement.getElementsByTagName("nd")[0].getAttribute("ref"));
谢谢,
托尼
【问题讨论】:
-
尝试使用 jaxb 上下文编组和解组
-
如何解压?请展示您目前尝试过的 Java 代码。