Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/solr/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
XSLT-提取除最后一小节外的所有文本_Xslt - Fatal编程技术网

XSLT-提取除最后一小节外的所有文本

XSLT-提取除最后一小节外的所有文本,xslt,Xslt,希望从xml中的完整类名解析出名称空间 数据示例: <results> <test-case name="Co.Module.Class.X"> </results> 我知道这个过程需要最后一个索引“.”才能调用一次,但我发现XSLT没有这个功能。如何最好地实现这一点?要在纯XSLT 1.0中实现这一点,需要调用命名的递归模板,例如: XSLT1.0 <xsl:stylesheet version="1.0" xmlns:xsl="http:

希望从xml中的完整类名解析出名称空间

数据示例:

<results>
    <test-case name="Co.Module.Class.X">
</results>

我知道这个过程需要最后一个索引“.”才能调用一次,但我发现XSLT没有这个功能。如何最好地实现这一点?

要在纯XSLT 1.0中实现这一点,需要调用命名的递归模板,例如:

XSLT1.0

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" encoding="UTF-8"/>

<xsl:template match="/results">
    <xsl:call-template name="remove-last-token">
        <xsl:with-param name="text" select="test-case/@name"/>
    </xsl:call-template>
</xsl:template>

<xsl:template name="remove-last-token">
    <xsl:param name="text"/>
    <xsl:param name="delimiter" select="'.'"/>
    <xsl:value-of select="substring-before($text, $delimiter)"/>
    <xsl:if test="contains(substring-after($text, $delimiter), $delimiter)">
        <xsl:value-of select="$delimiter"/>
        <xsl:call-template name="remove-last-token">
            <xsl:with-param name="text" select="substring-after($text, $delimiter)"/>
        </xsl:call-template>
    </xsl:if>
</xsl:template>

</xsl:stylesheet>

要在纯XSLT 1.0中执行此操作,需要调用命名的递归模板,例如:

XSLT1.0

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="text" encoding="UTF-8"/>

<xsl:template match="/results">
    <xsl:call-template name="remove-last-token">
        <xsl:with-param name="text" select="test-case/@name"/>
    </xsl:call-template>
</xsl:template>

<xsl:template name="remove-last-token">
    <xsl:param name="text"/>
    <xsl:param name="delimiter" select="'.'"/>
    <xsl:value-of select="substring-before($text, $delimiter)"/>
    <xsl:if test="contains(substring-after($text, $delimiter), $delimiter)">
        <xsl:value-of select="$delimiter"/>
        <xsl:call-template name="remove-last-token">
            <xsl:with-param name="text" select="substring-after($text, $delimiter)"/>
        </xsl:call-template>
    </xsl:if>
</xsl:template>

</xsl:stylesheet>

此纯XSLT 1.0转换(更短,无条件XSLT操作,单模板):


第二部分

稍加修改,以下转换将生成完整的CSV:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output method="text"/>
 <xsl:strip-space elements="*"/>

  <xsl:template match="test-case[contains(@name, '.')]">
  <xsl:param name="pDotIndex" select="0"/>

   <xsl:variable name="vNextToken" 
        select="substring-before(substring(@name, $pDotIndex+1), '.')"/>
   <xsl:value-of select="concat(substring(',', 2 - (position() > 1)),
                                substring('.', 2 - ($pDotIndex > 0)),  $vNextToken)"/>
   <xsl:variable name="vNewDotIndex" select="$pDotIndex+string-length($vNextToken)+1"/>
   <xsl:apply-templates 
        select="self::node()[contains(substring(@name,$vNewDotIndex+1), '.')]">
     <xsl:with-param name="pDotIndex" select="$vNewDotIndex"/>
   </xsl:apply-templates>
  </xsl:template>
</xsl:stylesheet>

此纯XSLT 1.0转换(更短,无条件XSLT操作,单模板):


第二部分

稍加修改,以下转换将生成完整的CSV:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output method="text"/>
 <xsl:strip-space elements="*"/>

  <xsl:template match="test-case[contains(@name, '.')]">
  <xsl:param name="pDotIndex" select="0"/>

   <xsl:variable name="vNextToken" 
        select="substring-before(substring(@name, $pDotIndex+1), '.')"/>
   <xsl:value-of select="concat(substring(',', 2 - (position() > 1)),
                                substring('.', 2 - ($pDotIndex > 0)),  $vNextToken)"/>
   <xsl:variable name="vNewDotIndex" select="$pDotIndex+string-length($vNextToken)+1"/>
   <xsl:apply-templates 
        select="self::node()[contains(substring(@name,$vNewDotIndex+1), '.')]">
     <xsl:with-param name="pDotIndex" select="$vNewDotIndex"/>
   </xsl:apply-templates>
  </xsl:template>
</xsl:stylesheet>

我认为您应该提供更多的信息,如输入数据、xsl样式表、输出和所需输出、最小完整可验证示例。。。(MCVE)我认为您应该提供更多信息,如输入数据、xsl样式表、输出和所需输出、最小完整可验证示例。。。(MCVE)
Co.Module.Class
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output method="text"/>
 <xsl:strip-space elements="*"/>

  <xsl:template match="test-case[contains(@name, '.')]">
  <xsl:param name="pDotIndex" select="0"/>

   <xsl:variable name="vNextToken" 
        select="substring-before(substring(@name, $pDotIndex+1), '.')"/>
   <xsl:value-of select="concat(substring(',', 2 - (position() > 1)),
                                substring('.', 2 - ($pDotIndex > 0)),  $vNextToken)"/>
   <xsl:variable name="vNewDotIndex" select="$pDotIndex+string-length($vNextToken)+1"/>
   <xsl:apply-templates 
        select="self::node()[contains(substring(@name,$vNewDotIndex+1), '.')]">
     <xsl:with-param name="pDotIndex" select="$vNewDotIndex"/>
   </xsl:apply-templates>
  </xsl:template>
</xsl:stylesheet>
<results>
    <test-case name="Co.Module.Class.X"/>
    <test-case name="Co2.Module2.Class2.Y"/>
    <test-case name="Co3.Module3.Class3.Z"/>
</results>
Co.Module.Class,Co2.Module2.Class2,Co3.Module3.Class3