0
String query = null;
XPathExpression expr;
Object Result = null;

expr = xpath.compile("//table/column[contains(translate(text(),'ABCDEFGHIJKLMNAOPQRSTUVWXYZ','abcdefghijklmnopqrstuvwxyz'),'"+query+"')]//text()");

result = expr.evaluate(doc, XpathConstants.NODESET);

NodeList nodes = (NodeList) result;

for (int i = 0; i<nodes.getLength(); i++){
     System.out.println(nodes.item(i).getParentNode().getNodeName() + "" + nodes.item(i).getNodeValue());
}

嗨,所以我想首先说我是 xpath 的新手,对 java 还很陌生。我正在尝试为这个大的 xml 文件创建一个查询界面,这就是我迄今为止想出的。xml 文件充满了日志,它的设置有点像这样......

 <database>
          <table>
               <column1>
               <column2>
               <column3>
               .....

该代码在拉回与搜索词匹配的列时效果很好,但是我希望它拉回整个表格然后将其打印出来。这将为我提供更多有价值的信息,包括输入它的人的日期戳等......我尝试了各种尝试从​​节点(i)获取父节点然后将 .getchildnodes 放入另一个节点列表但没有工作。我还尝试在 text() 之前的 xpath 末尾添加 /.. 以查看它是否会返回父级,但最终只是以某种方式给了我根标记。我想我有点接近,也许不是我不知道,但如果有人能提供帮助,我将不胜感激,我已经坚持了一段时间。

4

1 回答 1

0

你想用..而不是//

例如,要获取所有值为您tabletd值,xxx您可以使用

//table/tr/td[text() = 'xxx']/../..
于 2015-08-04T15:22:20.703 回答