我正在尝试使用Xslt2.0从String中提取Integer 例如,考虑字符串“designa80000dd5424d”,我需要字符串中的两个整数,即“8000”和“5424”
我尝试使用翻译功能,如下所示
select =“translate($ term,translate($ term,'0123456789',''),'')”
但它结合了两个整数并将输出结果为“80005424” 我需要一些能将它们分开的东西
答案 0 :(得分:2)
我尝试使用翻译功能,如下所示
select =“translate($ term,translate($ term,'0123456789',''),'')”
但它结合了两个数字,输出为“80005424”i 需要一些将它们分开的东西
<强>予。这是一个完整的XSLT 1.0解决方案:
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text"/>
<xsl:template match="/*">
<xsl:variable name="vSpaces">
<xsl:call-template name="makeSpaces"/>
</xsl:variable>
<xsl:variable name="vtheNumbers"
select="normalize-space(translate(., translate(.,'0123456789',''), $vSpaces))"/>
<xsl:call-template name="tokenize">
<xsl:with-param name="pStr" select="$vtheNumbers"/>
</xsl:call-template>
</xsl:template>
<xsl:template name="tokenize">
<xsl:param name="pStr"/>
<xsl:param name="pInd" select="1"/>
<xsl:if test="string-length($pStr)">
<xsl:value-of select=
"concat($pInd, ': ',substring-before(concat($pStr, ' '), ' '), '
')"/>
<xsl:call-template name="tokenize">
<xsl:with-param name="pStr" select="substring-after($pStr, ' ')"/>
<xsl:with-param name="pInd" select="$pInd +1"/>
</xsl:call-template>
</xsl:if>
</xsl:template>
<xsl:template name="makeSpaces">
<xsl:param name="pLen" select="string-length(.)"/>
<xsl:choose>
<xsl:when test="$pLen = 1">
<xsl:value-of select="' '"/>
</xsl:when>
<xsl:when test="$pLen > 1">
<xsl:variable name="vHalfLen" select="floor($pLen div 2)"/>
<xsl:call-template name="makeSpaces">
<xsl:with-param name="pLen" select="$vHalfLen"/>
</xsl:call-template>
<xsl:call-template name="makeSpaces">
<xsl:with-param name="pLen" select="$pLen -$vHalfLen"/>
</xsl:call-template>
</xsl:when>
</xsl:choose>
</xsl:template>
</xsl:stylesheet>
将此转换应用于以下XML文档:
<t>designa80000dd5424dan1733g122</t>
产生了想要的正确结果:
1: 80000
2: 5424
3: 1733
4: 122
请注意:
外部translate()
的最后一个参数是一个字符串,其字符数与输入字符串的字符数相同,并且每个字符都是一个空格。
<强> II。 XPath 2.0更短更简单
评估时,此XPath 2.0表达式生成所需的数字序列:
tokenize(., '[^\d]+')[.]
以下是基于XSLT的验证:
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:template match="/*">
<xsl:variable name="vNumbers"
select="tokenize(., '[^\d]+')[.]"/>
<xsl:for-each select="$vNumbers">
<xsl:value-of select="concat(position(), ': ', ., '
')"/>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
将此转换应用于同一XML文档:
<t>designa80000dd5424dan1733g122</t>
产生相同的正确结果:
1: 80000
2: 5424
3: 1733
4: 122
答案 1 :(得分:1)
您可以使用tokenize
尝试使用任何非数字序列作为分隔符,即使用XPath 3.0 tokenize('designa80000dd5424d', '[^0-9]+')[normalize-space()]!number()
或在XSLT / XPath 2.0中使用for $t in tokenize('designa80000dd5424d', '[^0-9]+')[normalize-space()] return number($t)
,或者您可以使用{{ 1}}(XSLT 2.0)或xsl:analyze-string
函数(XSLT / XPath 3.0,但Saxon 9.7 HE可用)。