如何从属性值中使用的字符串中删除引号?



我是第一次使用xlst语言。我遇到一个小问题,但我找不到解决办法。

XML示例:

<DATA>
    <KEY>1234</KEY>
    <VALUE>"AB"</VALUE>
</DATA>
<DATA>
    <CLE>4567</CLE>
    <VALUE>"CD"</VALUE>
</DATA>

我正在构建一个像这样的输入xml:

 <TestAlias Alias="{DATA[1]/KEY}" ExtRef="{DATA[1]/VALUE}"/>

结果几乎完美:

<ProjectAlias Alias="1234" ExtRef="**&#34**;AB**&#34**;"/>

问题是我的VALUE上的" "。当我做ExtRef="{DATA[1]/VALUE}"时,我可以选择不带它们吗?

这两种方法都可以用于您的示例:

1。

<TestAlias Alias="{DATA[1]/KEY}" ExtRef="{translate(DATA[1]/VALUE, '&quot;', '')}"/>

将删除所有引号;

2。

<TestAlias Alias="{DATA[1]/KEY}" ExtRef="{substring(DATA[1]/VALUE, 2, string-length(DATA[1]/VALUE) - 2)}"/>

或者,如果你喜欢:

<xsl:variable name="ext-ref" select="DATA[1]/VALUE" />
<TestAlias Alias="{DATA[1]/KEY}" ExtRef="{substring($ext-ref, 2, string-length($ext-ref) - 2)}"/>

将跳过第一个和最后一个字符。

相关内容

  • 没有找到相关文章

最新更新