Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/xml/15.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
Xml BaseX XSLT在返回第一个结果后失败_Xml_Xslt_Xquery_Basex - Fatal编程技术网

Xml BaseX XSLT在返回第一个结果后失败

Xml BaseX XSLT在返回第一个结果后失败,xml,xslt,xquery,basex,Xml,Xslt,Xquery,Basex,我有一个存储在BaseX中的大型XML文件,需要将其拆分为更小的模块化文档。为此,我创建了一个XSL文件: <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xs="http://www.w3.org/2001/XMLSchema" exclude-result-prefixes="xs" version="2.0"> <xsl:output indent

我有一个存储在BaseX中的大型XML文件,需要将其拆分为更小的模块化文档。为此,我创建了一个XSL文件:

<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:xs="http://www.w3.org/2001/XMLSchema"
    exclude-result-prefixes="xs"
    version="2.0">
    <xsl:output indent="yes" encoding="UTF-8"/>
    <xsl:param name="schema"/>
    <xsl:param name="model"/>
    <xsl:param name="sysDiff"/>
    <xsl:param name="sys"/>
    <xsl:param name="subsys"/>
    <xsl:param name="subsubsys"/>
    <xsl:param name="assy"/>
    <xsl:param name="disassy"/>
    <xsl:param name="disassyv"/>
    <xsl:param name="info"/>
    <xsl:param name="infov"/>
    <xsl:param name="itemloc"/>
    <xsl:param name="tname"/>
    <xsl:param name="iname"/>
    <xsl:param name="outputDir"/>

    <xsl:template match="/">
        <xsl:result-document href="{concat($outputDir, '/DMC-',$model,'-',$sysDiff,'-',$sys,'-',$subsys,$subsubsys,'-',$assy,'-',$disassy,$disassyv,'-',$info,$infov,'-',$itemloc,'.xml')}" method="xml">
            <dmodule>
                <identAndStatusSection>
                    <dmAddress>
                        <dmIdent>
                            <dmCode modelIdentCode="{$model}" systemDiffCode="{$sysDiff}">
                                <xsl:attribute name="systemCode" select="$sys"/>
                                <xsl:attribute name="subSystemCode" select="$subsys"/>
                                <xsl:attribute name="subSubSystemCode" select="$subsubsys"/>
                                <xsl:attribute name="assyCode" select="$assy"/>
                                <xsl:attribute name="disassyCode" select="$disassy"/>
                                <xsl:attribute name="disassyCodeVariant" select="$disassyv"/>
                                <xsl:attribute name="infoCode" select="$info"/>
                                <xsl:attribute name="infoCodeVariant" select="$infov"/>
                                <xsl:attribute name="itemLocationCode" select="$itemloc"/>
                            </dmCode>
                            <language languageIsoCode="en" countryIsoCode="US"/>
                            <issueInfo issueNumber="000" inWork="01"/>
                        </dmIdent>
                    </dmAddress>
                </identAndStatusSection>
            </dmodule>
        </xsl:result-document>    
    </xsl:template>
</xsl:stylesheet>

名为Book1-test.xml的文档本质上是现有元素ID到新输出文件名的映射。创建第一个XML输出文件后,BaseX返回错误[FODC0002]“”(第1行):文件过早结束。当我在BaseX文档中查找错误代码时,此错误被定义为“无法检索指定的文档资源”。。在循环中使用xslt:transform函数是否有一些限制?我不明白为什么它能在第一次取回,但在那之后就不能了。我尝试将XSL移动到不同的文件位置,但没有成功。我是不是遗漏了一些非常明显的东西?

我认为BaseX邮件列表上的Gerrit Imsieke给出了正确的解释,BaseX没有处理XSLT的第二个输入,它没有将第一次调用XSLT:transform的空结果转换为它的任何XQuery表示。因此,使用
xslt:transformtext
应该可以解决您的问题。或者让XSLT输出一个带有根元素的主要结果。

这可能是一个bug,我认为理想的方法是在BaseX邮件列表上请求确认,然后他们在上打开一个问题。对于您拥有的简单样式表(您只是使用从XQuery传入的参数填充一些结果元素),您当然应该能够在XQuery(
)中使用
fn:put
或编写文件来完成这些工作,而不必使用XSLT。这只是XSLT的开始,节点将从BaseX数据库中提取($newD)然后将被转换为新文件的内容。我用这个简单的开始让这个过程开始。我可能会采取文件模块的方法,在DB环境之外执行XSLT。BaseX在修复bug方面相当快,因此如果您告诉他们有关问题,您可能会在几天或更短的时间内得到一个新的快照并进行修复。请注意,有一个奇怪之处,您的样式表在
/
上匹配,这将是一个文档节点,但您传入了一个元素节点
$newD
,因此您的样式表可能不会达到您预期的效果。它创建的单个输出正是我在这个最小的开始时所预期的。我的想法是,在BaseX中检索每个节点时,每个结果都被视为独立文档,我正在转换一个新的独立文档。我成功地查询了所有325个结果并将其保存到单独的文档中,我可能只是对这些结果运行XSL,而不是通过BaseX。使用xslt:transform-text()函数实现了这一点。谢谢你的帮助,马丁。
 let $style := doc('file:///C:/base.xsl')

   for $d in doc('file:///C:/Users/tfurst/Documents/Book1-test.xml')//title
      for $newD in //*[title]
      where $newD/title/@id eq $d/@id
        let $schema := $d/schemaName
        let $model := $d/modelic
        let $sdc := $d/sdc
        let $sys := $d/systemCode
        let $subsys := $d/subsys
        let $subsubsys := $d/subsubsys
        let $assy := $d/assy
        let $disassy := $d/disassy
        let $disassyv := $d/disassyv
        let $info := $d/infoCode
        let $infov := $d/infov
        let $itemloc := $d/itemloc
        let $tname := $d/tname
        let $iname := $d/iname
        return xslt:transform($newD,$style, map {"outputDir":"file:///G:/LMA-Conv/Flight/test-conv-out", "model":$model, "sysDiff":$sdc, "sys":$sys, "subsys":$subsys, "subsubsys":$subsubsys, "assy":$assy, "disassy":$disassy, "disassyv":$disassyv, "info":$info, "infov":$infov, "itemloc":$itemloc, "tname":$tname, "iname":$iname})