重複節點考慮下面的XML:去除XSL輸出
<record>
<category>Sport/Racket Sports/Tennis</category>
<category>Sport/Racket Sports/Badminton</category>
</record>
我想分手,這樣下面的XML產生的類別:
<add>
<doc>
<field name="category_0">Sport</field>
<field name="category_1">Sport/Racket Sports</field>
<field name="category_2">Sport/Racket Sports/Tennis</field>
<field name="category_2">Sport/Racket Sports/Badminton</field>
</doc>
</add>
我已經成功地產生的東西幾乎在那裏..我現在需要一種方法來刪除重複?有任何想法嗎?
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output indent="yes"/>
<xsl:template match="record">
<add>
<doc>
<xsl:for-each select="category[. != '']">
<xsl:call-template name="split-cats">
<xsl:with-param name="prefix" select="''"/>
<xsl:with-param name="text" select="."/>
<xsl:with-param name="level" select="number(0)"/>
</xsl:call-template>
</xsl:for-each>
</doc>
</add>
</xsl:template>
<xsl:template name="split-cats">
<xsl:param name="text" select="."/>
<xsl:param name="prefix"/>
<xsl:param name="level" select="0"/>
<xsl:choose>
<xsl:when test="contains($text, '/')">
<field>
<xsl:attribute name="name">
<xsl:text>category_</xsl:text><xsl:value-of select="$level"/>
</xsl:attribute>
<xsl:value-of select="concat($prefix, substring-before($text, '/'))"/>
</field>
<xsl:call-template name="split-cats">
<xsl:with-param name="prefix" select="concat($prefix, concat(substring-before($text, '/'), '/'))"/>
<xsl:with-param name="text" select="substring-after($text, '/')"/>
<xsl:with-param name="level" select="$level + 1"/>
</xsl:call-template>
</xsl:when>
<xsl:otherwise>
<field>
<xsl:attribute name="name">
<xsl:text>category_</xsl:text><xsl:value-of select="$level"/>
</xsl:attribute>
<xsl:value-of select="concat($prefix, $text)"/>
</field>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
</xsl:stylesheet>
這個模板產生:
<add>
<doc>
<field name="category_0">Sport</field>
<field name="category_1">Sport/Racket Sports</field>
<field name="category_2">Sport/Racket Sports/Tennis</field>
<field name="category_0">Sport</field>
<field name="category_1">Sport/Racket Sports</field>
<field name="category_2">Sport/Racket Sports/Badminton</field>
</doc>
</add>
正如你可以看到有Sport
和Sport/Racket Sports
在那裏兩次:(
FYI:我需要能夠做到這一點使用XSLT 1.0
謝謝
戴夫
請,在一個單獨的問題中解釋什麼是產出的要求/規則(特別是,它不是清算如何形成類別名稱)。我認爲可以生成更簡單的解決方案,並且可以完全避免重複的問題。 – 2011-01-11 14:04:45
啊是的..對不起,數字表示「0」是根級別的類別的「級別」。在這種情況下,「體育」和「1」是子類別的第一級別,2是子類別的第二級別等等。這是用來將文檔發送到Solr的符號。看看這封電子郵件http://search.lucidimagination中的第三個選項。com/search/document/8a14673728e3a722/implements_hierarchical_facet – CraftyFella 2011-01-11 14:10:41