我们将 XSL 样式表应用于许多具有不同结构和标签的 XML 文件。我们希望对所有文件使用单个 XSL 样式表,如果添加了具有新内容结构的 XML 文件,我们可以在其中简单地添加新的 xpath。
(我可能会补充一点,这是与 Apache 的 Solr 一起使用的,输出文档需要以某种方式显示。)
到目前为止,我们已经成功编写了复制各个字段的代码,如下所示:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xalan="http://xml.apache.org/xslt" xmlns:exslt="http://exslt.org/common" version="1.0">
<xsl:output method="xml" encoding="UTF-8" indent="yes" xalan:indent-amount="4" omit-xml-declaration="yes"/>
<xsl:template match="/">
<xsl:param name="fileName" />
<xsl:param name="fileURI" />
<xsl:param name="timeCreatedLong" />
<add>
<doc>
<!-- REQUIRED FIELDS. DO NOT CHANGE -->
<field name="fileName"><xsl:value-of select="$fileName" /></field>
<field name="fileURI"><xsl:value-of select="$fileURI" /></field>
<field name="timeCreatedLong"><xsl:value-of select="$timeCreatedLong" /></field>
<!-- //END OF REQUIRED FIELDS -->
<!-- DSV INTERNAL XML -->
<!-- Consignment Identifiers -->
<field name="consignmentIdentifiers"><xsl:value-of select="//consignmentlist/consignment/consignmentId" /></field>
<field name="consignmentIdentifiers"><xsl:value-of select="//consignmentlist/consignment/references/reference[@type = 'consignment_number']/value" /></field>
<!-- //Consignment Identifiers -->
<!-- Transport company information -->
<field name="carrier"><xsl:value-of select="//transport/transportservice/carriername" /></field>
<field name="carrierService"><xsl:value-of select="//transport/transportservice/carrierservicename" /></field>
<field name="transportMode"><xsl:value-of select="//transport/transportservice/transportmode" /></field>
<!-- //Transport company information -->
<!-- //DSV INTERNAL XML -->
<!-- POSTEN NORDIC LOGISTICS ORDER.XML -->
<!-- Consignment Identifiers -->
<field name="consignmentIdentifiers"><xsl:value-of select="//TransportJob/Consignment/@consignmentId" /></field>
<!-- //Consignment Identifiers -->
<!-- Transport company information -->
<field name="definedBy"><xsl:value-of select="//TransportJob/@definedBy" /></field>
<field name="carrier"><xsl:value-of select="//TransportJob/@profile" /></field>
<!-- //Transport company information -->
<!-- //POSTEN NORDIC LOGISTICS ORDER.XML -->
</doc>
</add>
</xsl:template>
</xsl:stylesheet>
根据处理的文件结构,输出看起来像这样:
<add>
<doc>
<field name="fileName">00373323993931432015_BOOKING.INTERNALXML</field>
<field name="fileURI">/usr/dropbox/Dropbox/shared/file-search/00373323993931432015_BOOKING.INTERNALXML</field>
<field name="timeCreatedLong">1377507872000</field>
<field name="consignmentIdentifiers"/>
<field name="consignmentIdentifiers">00373323993931432015</field>
<field name="carrier">DSV</field>
<field name="carrierService">DSV Mypack</field>
<field name="transportMode">ROAD</field>
<field name="consignmentIdentifiers"/>
<field name="definedBy"/>
<field name="carrier"/>
</doc>
</add>
如您所见,我们有一些空的/自动关闭的元素,我们希望在将其发送到我们的 Solr 服务器之前将其删除。
所以真正的问题是,有没有办法在应用这个 XSL 之后删除生成的空标签?如上所述,我们希望这在同一个 XSL 文件中完成。