【发布时间】:2021-12-04 04:16:46
【问题描述】:
我正在使用 XSLT 1.0 和 XML。我是这些主题的新手,但我一直在阅读并尝试如何将 XSLT 应用于 XML。
现在,我给出了一个需要从 XML 元素中过滤掉无效字段的项目。 java Transformer 类用于在 XML 上应用 XSLT。
java代码类似于"Writing an XSLT Transform"部分下的oracle教程页面。我添加了以下 xml 和 xsl 并运行教程页面中描述的代码。我的目标是提取单引号和双引号以及以下字符#60;•^#x6;
XML 文件
<?xml version="1.0" encoding="UTF-8"?>
<Author>
<Name>
<FirstName>Ch#60;•^#x6;'""ris</FirstName>
<LastName>Banville</LastName>
</Name>
</Author>
XSL 文件
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<xsl:variable name="invalid">#60;•^#x6;"'</xsl:variable>
<div>
<xsl:value-of select="translate(/Author/Name/FirstName,$invalid,'')" />
</div>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
最终输出是
<body>
<div>Chris</div>
</body>
我的问题是,在使用 XSLT 1.0 来同时转义单引号和双引号以及其他无效字符时,正确的方法是什么?我也试过嵌套
翻译
创建“单”和“双”变量后的XSLT函数如下图所示。
<xsl:value-of select="translate(translate(/Author/Name/FirstName,$single,''),$double,'')" />
我仍然不确定使用我当前的任何实现的利弊,或者即使它是执行此类任务的正确方法。
【问题讨论】: