Xml BaseX XSLT在返回第一个结果后失败
我有一个存储在BaseX中的大型XML文件,需要将其拆分为更小的模块化文档。为此,我创建了一个XSL文件: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
<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})