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 末尾添加 /.. 以查看它是否会返回父级,但最终只是以某种方式给了我根标记。我想我有点接近,也许不是我不知道,但如果有人能提供帮助,我将不胜感激,我已经坚持了一段时间。