【问题标题】:Extract attribute of an element from XML从 XML 中提取元素的属性
【发布时间】: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 代码。

标签: java xml xpath


【解决方案1】:

这种语法在 Java 中不起作用。

System.out.println(wElement.getElementsByTagName("nd")[0].getAttribute("ref"));

您需要在此处更改两件事。首先Java使用.item(0)而不是[0],其次因为Java是强类型的,而getAttributeElement的方法而不是Node,你需要一个演员表:

System.out.println(((Element)wElement.getElementsByTagName("nd").item(0))
                    .getAttribute("ref"));

【讨论】:

  • 谢谢你,伊恩。第一次使用stackflow,得到了这么及时的回复。
【解决方案2】:

以下代码可用于获取 ref 属性的值并将它们存储在 arraylist 中。

String s="<?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>";


    DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
    builderFactory.setNamespaceAware(true);
    InputSource is = new InputSource(new StringReader(s));


    DocumentBuilder builder;
    try {
        builderFactory.setIgnoringElementContentWhitespace(true);
        builder = builderFactory.newDocumentBuilder();
        Document xml = builder.parse(is);
        XPathFactory factory = javax.xml.xpath.XPathFactory.newInstance();
        XPath xPath = factory.newXPath();
        XPathExpression expression;

        expression = xPath.compile("/osm/way/nd/@ref");
        NodeList ss = (NodeList) expression.evaluate(xml,XPathConstants.NODESET);
        ArrayList<String> list = new ArrayList<String>();
        for (int i = 0; i < ss.getLength(); i++) {
            list.add(ss.item(i).getTextContent());
        }
        System.out.println(list);
    } catch (ParserConfigurationException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (SAXException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (XPathExpressionException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }   
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-02-12
    • 1970-01-01
    • 1970-01-01
    • 2021-05-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多