我是第一次使用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="**"**;AB**"**;"/>
问题是我的VALUE上的" "。当我做ExtRef="{DATA[1]/VALUE}"
时,我可以选择不带它们吗?
这两种方法都可以用于您的示例:
1。
<TestAlias Alias="{DATA[1]/KEY}" ExtRef="{translate(DATA[1]/VALUE, '"', '')}"/>
将删除所有引号;
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)}"/>
将跳过第一个和最后一个字符。