java saxon,在Java中使用SAXON Xpath引擎

这是我的代码:

public static void main(String[] args) {

// System.setProperty(

// "javax.xml.xpath.XPathFactory",

// "net.sf.saxon.xpath.XPathFactoryImpl");

String xml="#BBB##CCC##DDD#";

try{

JDocument dom = new JDocument(xml);

XPathFactory factory = net.sf.saxon.xpath.XPathFactoryImpl.newInstance();

XPath xpath = factory.newXPath();

XPathExpression expr = xpath.compile("//a[matches(.,'#...#')]");

Object result = expr.evaluate(dom, XPathConstants.NODESET);

NodeList nodes = (NodeList) result;

Nodes sharped = new Nodes(nodes);

for (Node n:sharped){

System.out.println(n.toString());

}

}

catch(Exception e){

e.printStackTrace();

}

}

我明白了:

javax.xml.transform.TransformerException: Impossible to find the function : matches

at org.apache.xpath.compiler.XPathParser.error(XPathParser.java:608)

at org.apache.xpath.compiler.XPathParser.FunctionCall(XPathParser.java:1505)

at org.apache.xpath.compiler.XPathParser.PrimaryExpr(XPathParser.java:1444)

at org.apache.xpath.compiler.XPathParser.FilterExpr(XPathParser.java:1343)

at org.apache.xpath.compiler.XPathParser.PathExpr(XPathParser.java:1276)

这意味着当我通过net.sf.saxon.xpath.XPathFactoryImpl清楚地创建我的工厂时,Java正在使用org.apache.xpath.compiler.XPathParser类.

(我实际上只需要在我的xpaths中添加一些匹配…所以如果任何不涉及Saxon的解决方案已知,请考虑我的需求.)

我究竟做错了什么 ?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java使用xQuery可以通过以下步骤实现: 1. 引入xQuery解析器:Java可以使用Saxon或XMLStarlet来解析xQuery语句,需要在项目引入相关的jar包。 2. 创建xQuery查询语句:使用xQuery语言编写需要执行的查询语句。 3. 创建XML文档:将需要查询的XML数据存储在一个XML文件。 4. 解析XML文档:使用Java的DOM或SAX解析器解析XML文档。 5. 执行xQuery查询:将查询语句传递给xQuery解析器,并执行查询操作。 6. 处理查询结果:解析器返回查询结果,Java程序可以将结果存储在内存或输出到文件等。 以下是一个使用Saxon解析器执行xQuery查询的Java示例代码: ```java import net.sf.saxon.s9api.*; public class XQueryExample { public static void main(String[] args) throws SaxonApiException { // 创建xQuery查询语句 String xquery = "for $x in doc('example.xml')//book where $x/price>30 return $x/title"; // 创建Processor和XQueryCompiler对象 Processor processor = new Processor(false); XQueryCompiler compiler = processor.newXQueryCompiler(); // 编译查询语句 XQueryExecutable exec = compiler.compile(xquery); // 创建XQueryEvaluator对象 XQueryEvaluator query = exec.load(); // 解析XML文档 DocumentBuilder builder = processor.newDocumentBuilder(); XdmNode doc = builder.build(new File("example.xml")); // 设置查询上下文 query.setContextItem(doc); // 执行查询并处理结果 XdmValue result = query.evaluate(); for (XdmItem item : result) { System.out.println(item.getStringValue()); } } } ``` 以上代码使用Saxon解析器执行了一个xQuery查询,查询了一个XML文档价格大于30的书籍的标题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值