加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

尝试使用XSLT转换XML,但输出行中断

发布时间:2020-12-16 23:09:59 所属栏目:百科 来源:网络整理
导读:尝试使用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:t
尝试使用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,')')" />

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读