我是以下的XML。
<para>28A.45</para>
<para>28R.45</para>
以下的XSLT就是我尝试过的
<xsl:template match="text()">
<xsl:analyze-string select="." regex="([\w]+)\.([\w]+)">
<xsl:matching-substring>
<xsl:variable name="translated" select="fn:translate(regex-group(1),'ABCDEFGHIJKLMNOPQRSTUVWXYZ','')"/>
<xsl:if test="number($translated) > 27 and number($translated) < 40">
<xsl:choose>
<xsl:when test="contains('A | B | C | D', regex-group(1))">
<xsl:text>PT_05</xsl:text>
</xsl:when>
<xsl:when test="contains('E | F | G | H | I | J | K | L | M | N | O | P | Q | R', regex-group(1))">
<xsl:text>PT_06</xsl:text>
</xsl:when>
<xsl:otherwise>
<xsl:text>PT_04</xsl:text>
</xsl:otherwise>
</xsl:choose>
</xsl:if>
</xsl:matching-substring>
<xsl:non-matching-substring>
<xsl:value-of select="."/>
</xsl:non-matching-substring>
</xsl:analyze-string>
</xsl:template>
根据上述条件,第一个para
应打印PT_05
,第二个para
应打印PT_06
但是获取的输出为PT_04
(否则条件)。
答案 0 :(得分:1)
这是我的回答
<xsl:template match="text()">
<xsl:analyze-string select="." regex="([\w]+)\.([\w]+)">
<xsl:matching-substring>
<xsl:variable name="translated" select="fn:translate(regex-group(1),'ABCDEFGHIJKLMNOPQRSTUVWXYZ','')"/>
<xsl:if test="number($translated) > 27 and number($translated) < 40">
<xsl:choose>
<xsl:when test="contains(regex-group(1), 'A') or contains(regex-group(1), 'B') or contains(regex-group(1), 'C') or contains(regex-group(1), 'D')">
<xsl:text>PT_05</xsl:text>
</xsl:when>
<xsl:when test="contains(regex-group(1),'E') or contains(regex-group(1),'F') or contains(regex-group(1),'G') or
contains(regex-group(1),'H') or contains(regex-group(1),'I') or contains(regex-group(1),'J') or contains(regex-group(1),'K') or
contains(regex-group(1),'L') or contains(regex-group(1),'M') or contains(regex-group(1),'N')
or contains(regex-group(1),'O') or contains(regex-group(1),'P') or
contains(regex-group(1),'Q') or contains(regex-group(1),'R')">
<xsl:text>PT_06</xsl:text>
</xsl:when>
<xsl:otherwise>
<xsl:text>PT_04</xsl:text>
</xsl:otherwise>
</xsl:choose>
</xsl:if>
</xsl:matching-substring>
<xsl:non-matching-substring>
<xsl:value-of select="."/>
</xsl:non-matching-substring>
</xsl:analyze-string>
</xsl:template>
这完美无缺。