尝试使用XSLT转换 XML,但输出行中断. 这是我的代码: ?xml version="1.0" encoding="UTF-8"?xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"xmlns:xs="http://www.w3.org/2001/XMLSchema"exclude-result-prefixes="xs"v
这是我的代码:
<?xml version="1.0" encoding="UTF-8"?> <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xs="http://www.w3.org/2001/XMLSchema" exclude-result-prefixes="xs" version="1.0"> <xsl:template match="/" > <data> <content> <xsl:for-each select="//t[@pos='ADV' or @pos='ADJD' or @pos='ADJA' or @pos='NE' or @pos='NN' or @pos='VMFIN' or @pos='VVINF' or @pos='VAFIN' or @pos='VVPP' or @pos='VVFIN']"> <xsl:sort select="@word"/> <token> <xsl:value-of select="@word"/> (<xsl:value-of select="@lemma"/>; <xsl:value-of select="@pos"/>; <xsl:value-of select="@morph"/>) </token> </xsl:for-each> </content> </data> </xsl:template> </xsl:stylesheet>
我得到这个作为输出:
<?xml version="1.0" encoding="utf-8"?><data><content><token>Aktivitäten (Aktivität; NN; Acc.Pl.Fem) </token><token>Bank (Bank; NN; Dat.Sg.Fem) </token><token>Behörden (Behörde; NN; Dat.Pl.Fem) </token>
我试图复制这个输出结果
<?xml version="1.0" encoding="UTF-8"?> <data> <content> <token>Aktivitäten(Aktivität;NN;Acc.Pl.Fem)</token> <token>Bank(Bank;NN;Dat.Sg.Fem)</token> <token>Behörden(Behörde;NN;Dat.Pl.Fem)</token> etc...
我是XSLT的新手,感谢您的帮助
与其他文字文本(如(,;,和))相邻时,通常无关紧要的空白区域变得非常重要.如果你在xsl:text中包装每个字符串(字符),
<xsl:value-of select="@word"/> <xsl:text>(</xsl:text> <xsl:value-of select="@lemma"/> <xsl:text>;<xsl:text> ...
你会得到你想要的XML输出.
另一种方法[感谢@Tomalak]消除不需要的空白区域是在单个xsl:value-of中连接字符串值:
<xsl:value-of select="concat(@word, '(', @lemma, ';', @pos, ';', @morph, ')')" />