Regex 如何在xsl中使用正则表达式

Regex 如何在xsl中使用正则表达式,regex,xml,xslt,xslt-1.0,Regex,Xml,Xslt,Xslt 1.0,我有一个xml格式的请求。这是CDATA <cmd> <![CDATA[HG<><><36.75><0420>< ><HS6011201700446279><><>< >< >< ><><>< ><>< >< ><>< ><&g

我有一个xml格式的请求。这是CDATA

<cmd>
     <![CDATA[HG<><><36.75><0420>< ><HS6011201700446279><><>< >< ><  ><><><  ><><  ><  ><><  ><><  ><>]]>
</cmd>

< >< >< ><  ><  ><  ><  ><  ><  >]]>
我需要从cdata路径提取HS6011201700446279

下面是他们给出的正则表达式。如何在xsl中使用它

HG<\\s*><\\s*><.*><.*><.*><[A-Z]{2}(\\d{10,}).*

HGXSLT1.0中不支持正则表达式。假设所需的子字符串位于给定字符串的第6个“标记”内,则可以通过调用递归命名模板来提取它:

<xsl:template match="cmd">
    <result>
        <xsl:call-template name="get-Nth-value">
            <xsl:with-param name="list" select="."/>
            <xsl:with-param name="N" select="6"/>
        </xsl:call-template>
    </result>
</xsl:template>

<xsl:template name="get-Nth-value">
    <xsl:param name="list"/>
    <xsl:param name="N"/>
    <xsl:param name="delimiter" select="'>&lt;'"/>
    <xsl:choose>
        <xsl:when test="$N = 1">
            <xsl:value-of select="substring-before(concat($list, $delimiter), $delimiter)"/>
        </xsl:when>
        <xsl:when test="contains($list, $delimiter) and $N > 1">
            <!-- recursive call -->
            <xsl:call-template name="get-Nth-value">
                <xsl:with-param name="list" select="substring-after($list, $delimiter)"/>
                <xsl:with-param name="N" select="$N - 1"/>
                <xsl:with-param name="delimiter" select="$delimiter"/>
            </xsl:call-template>
        </xsl:when>
    </xsl:choose>
</xsl:template> 


看看这个,为什么xml文件中有文本
s?如果“xml文件”中确实包含这些字符,那么您的文件就不是xml文件,不能使用xslt。否则,也许您应该编辑您的问题,并显示文件的确切内容。事实上,你的问题完全不清楚。实际上它是xml格式的CDATA。更新了输入XML可能需要使用扩展(如脚本)-XSLT1.0中没有内置正则表达式。您也可以拆分字符串并手动处理它-但是在纯xslt 1.0中这有点痛苦。检查您的xslt处理器是否支持EXSLT正则表达式库我们可以使用EXSLT正则表达式吗?如果您的处理器支持它。您将使用哪个处理器?我们正在使用datapower。它支持exslt功能,我想你可以。至少他说你可以。我自己不是用户,所以我不能凭经验说话请注意,每个XSLT1.0处理器都支持一些EXSLT函数——这并不意味着它支持所有函数。对正则表达式的支持尤其少见。