我有一个带有通用路径前缀的XPath表达式列表。例如,我可能有如下内容:
Elements/Bills/Amount/USD
Elements/Id我要做的是首先获得所有的元素节点,然后,对于给定的节点,检查它是否包含我想要的两个数据点(我需要从顶部开始检查每个节点)。像node.get(/Bills/Amount/USD), node.get(/Id)这样的东西将是完美的。但是,在编译和执行Elements(xPath.compile(Elements).evaluate(doc, XPathConstants.NODESET);).
发布于 2016-10-20 05:44:29
在后续对evaluate()的调用中传递node。第一个调用是使用文档作为“上下文”(https://msdn.microsoft.com/en-us/library/ms256199(v=vs.110).aspx,这意味着xml文档的根被认为是上下文)(基本上就是搜索开始的地方)。
一旦我有了一个节点,我就把它和路径的剩余部分一起传递给下一次对evaluate()的调用。
第一次调用(返回Elements列表):
xPath.compile("Elements").evaluate(doc, XPathConstants.NODESET)第二个调用(返回当前Element节点的子节点的所有USD元素):
xPath.compile("./Bills/Amount/USD").evaluate(node, XPathConstants.NODESET) https://stackoverflow.com/questions/40140704
复制相似问题