3

我有这样的 XML 文件:

<books>
<book>
    <id>1</id>
    <validFrom>23.11.2012</validFrom>
    <validTo>26.09.2012</validTo>
</book>
<book>
    <id>2</id>
    <validFrom>14.09.2012</validFrom>
    <validTo>01.08.2012</validTo>
</book>

我想从此 xml 文件中删除所有书籍,其中 datevalidTo 早于当前日期,但我在 XPath 中查询时遇到问题。

我尝试了不同的方式。

XPathFactory xPathFactory = XPathFactory.newInstance();
        XPath xpath = xPathFactory.newXPath();
        XPathExpression expr 
         = xpath.compile("//book[validTo < fn:current-date()]");

Object result = expr.evaluate(doc, XPathConstants.NODESET);
    NodeList nodes = (NodeList) result;
    for (int i = 0; i < nodes.getLength(); i++) {
        removeFindNodes()
    }

如何格式化 validTo 以便能够与当前日期进行比较?

谢谢你的帮助

4

1 回答 1

1

xsd:date期望格式为yyyy-MM-dd,而您的格式为dd.MM.yyyy. 您可以尝试使用 、 和 的组合substringtranslate转换concat您的格式,但到那时您的 XPath 表达式会变得稍微复杂一些。另一种更容易阅读的解决方案是获取所有validTo节点,然后与 Java 进行比较:

XPathExpression expr = xpath.compile("//book/validTo");
Object result = expr.evaluate(doc, XPathConstants.NODESET);
NodeList nodes = (NodeList) result;

DateFormat df = new SimpleDateFormat("dd.MM.yyyy");
Calendar now = Calendar.getInstance();
now.set(Calendar.HOUR_OF_DAY, 0);
now.set(Calendar.MINUTE, 0);
now.set(Calendar.SECOND, 0);
now.set(Calendar.MILLISECOND, 0);

for (int i = 0; i < nodes.getLength(); i++) {
  Node validToNode = nodes.item(i);
  Date validTo = df.parse(validToNode.getTextContent());
  if (validTo.compareTo(now.getTime()) < 0) {
    Node bookNode = validToNode.getParentNode();
    removeNode(bookNode);
  }
}
于 2012-09-23T21:11:56.133 回答