我想使用Java中的XPath读取XML数据,因此对于我收集的信息,我无法根据需要解析XML。
这是我想做的:
通过其URL从联机获取XML文件,然后使用XPath对其进行解析,我想在其中创建两个方法。一种是输入特定的节点属性ID,然后得到所有的子节点,第二种是假设我只想获得一个特定的子节点值
<?xml version="1.0"?> <howto> <topic name="Java"> <url>http://www.rgagnonjavahowto.htm</url> <car>taxi</car> </topic> <topic name="PowerBuilder"> <url>http://www.rgagnon/pbhowto.htm</url> <url>http://www.rgagnon/pbhowtonew.htm</url> </topic> <topic name="Javascript"> <url>http://www.rgagnon/jshowto.htm</url> </topic> <topic name="VBScript"> <url>http://www.rgagnon/vbshowto.htm</url> </topic> </howto>
在上面的示例中,如果我通过@name搜索,我想读取所有元素,并且我想只从@name’Javascript’中获取url的一个函数只返回一个节点元素。
你需要遵循以下要求:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document doc = builder.parse(<uri_as_string>); XPathFactory xPathfactory = XPathFactory.newInstance(); XPath xpath = xPathfactory.newXPath(); XPathExpression expr = xpath.compile(<xpath_expression>);
然后,调用expr.evaluate()传入该代码中定义的文档以及所需的返回类型,然后将结果转换为结果的对象类型。
expr.evaluate()
如果你需要有关特定XPath表达式的帮助,则可能应该将其作为单独的问题进行询问(除非首先是你的问题-我理解你的问题是如何在Java中使用API)。
编辑:(响应评论):此XPath表达式将为你提供PowerBuilder下第一个URL元素的文本:
/howto/topic[@name='PowerBuilder']/url/text()
这将使你获得第二个优势:
/howto/topic[@name='PowerBuilder']/url[2]/text()
你可以通过以下代码获得该代码:
expr.evaluate(doc, XPathConstants.STRING);
如果你不知道给定节点中有多少个URL,那么你应该这样做:
XPathExpression expr = xpath.compile("/howto/topic[@name='PowerBuilder']/url"); NodeList nl = (NodeList) expr.evaluate(doc, XPathConstants.NODESET);
然后循环遍历NodeList。