XSLT转换
普通取值
<xsl:attribute name="value"><xsl:value-of select="Xpath路径"/></xsl:attribute>
循环取值
<xsl:for-each select="/PRVS_IN000001UV01/controlActProcess/subject/registrationRequest/subject1/valueSet/entity">
<concept>
<!--定义一个变量,赋值循环次数,在xpath中调用变量-->
<xsl:variable name='title' select='position()'/>
<code>
<xsl:attribute name="value"><xsl:value-of select="/PRVS_IN000001UV01/controlActProcess/subject/registrationRequest/subject1/valueSet/entity[$title]/valueSetItem[2]/desc/@value"/></xsl:attribute>
</code>
<display>
<xsl:attribute name="value"><xsl:value-of select="/PRVS_IN000001UV01/controlActProcess/subject/registrationRequest/subject1/valueSet/entity[$title]/valueSetItem[1]/desc/@value"/></xsl:attribute>
</display>
</concept>
</xsl:for-each>
用for-each进行循环 select来查找循环节点,通过
<xsl:variable name='title' select='position()'/>
设置一个计数器,通过 $title 来调用计数器的次数。
从CDATA[]中取值
<!--从CDATA中取值-->
<xsl:attribute name="value"><xsl:value-of select="substring-before(substring-after(.,'<OUTP_OR_INP>'),'</OUTP_OR_INP>')"/></xsl:attribute>
在CDATA中有需要的值,想要获取但是普通的通过Xpath路径来查找没有用,就通过上面代码就可以获取,只需要更改节点名字即可,将OUTP_OR_INP换成需要查找的节点名。