xml - 尝试使用 XSLT 转换 XML,但输出换行符

标签 xml xslt xslt-1.0

尝试使用 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"
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, ')')" />

关于xml - 尝试使用 XSLT 转换 XML,但输出换行符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49961617/

相关文章:

php - 单击提交后如何重定向我指向的 url?

Javascript xml空标签错误

xml - 将十六进制颜色代码转换为 HSL 值,反之亦然?

xslt 1 : check if node contains any value from list

html - 在 XSLT 中如何将父项的第一个子项中的属性移动到父项?

c# - ArgumentException:C# 中的 'Illegal characters in path'

xml - XSD : Check order of child elements based on attribute

JSON 到 XSLT : default XML node if JSON element does NOT exist

XSLT:如果节点不存在,则创建节点?

xslt - 如何强制 xslt 转换以将数据加载到 cdata 部分?