0

解決しなければならない XSLT の問題があります。XSLT にはかなり慣れていません。ここの XSLT エキスパートは素晴らしいですが、問題の正確な解決策を見つけることができませんでした。重複した本を排除する必要があります。 +ブックネーム。しかし、CD のような他のノードや親ノード内の他のノードに複製を適用したくありません。複製をブックノードだけに適用するように制限するにはどうすればよいですか。ここで入力出力の観点からこれを学ぼうとしていますが、実際の変換がどのように行われるかを見逃している可能性があります。

もうありがとう!

XML:

<ListOfRowIDWithListOfBooks xmlns:bpws="http://schemas.xmlsoap.org/ws/2003/03/business-process/">
  <RowIDWithListOfBooks>
    <ListOfBookInfo>
      <book>
        <BookType>Brand</BookType>
        <BookName>jon</BookName>
      </book>
      <book>
        <BookType>Brand</BookType>
        <BookName>jon</BookName>
      </book>
      <CD>
        <CDType>Country</CDType>
        <CDName>MaxStar</CDName>
      </CD>
    </ListOfBookInfo>
  </RowIDWithListOfBooks>
</ListOfRowIDWithListOfBooks>

XSLT:  I have developed so far, Dimitre, thanks much sir! u have been a great help

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <!--Key-->
  <xsl:key name="k-books" match="book" use="concat(BookType,'|',BookName)"/>
  <!--Global match template-->
  <xsl:template match="@* | node()">
    <xsl:copy>
      <xsl:apply-templates select="@* | node()"/>
    </xsl:copy>
  </xsl:template>
  <!--Eliminate duplicate book nodes template-->
  <xsl:template match="ListOfBookInfo">
            <xsl:copy>
                <xsl:apply-templates select="book
                [generate-id()
                =generate-id(key('k-books',concat(BookType,'|',BookName))[1])]"/>
            </xsl:copy>
    </xsl:template>
</xsl:stylesheet>      

出力:

<?xml version="1.0"?>
<ListOfRowIDWithListOfBooks xmlns:bpws="http://schemas.xmlsoap.org/ws/2003/03/business-process/">
<RowIDWithListOfBooks>
<ListOfBookInfo><book>
<BookType>Brand</BookType>
<BookName>jon</BookName>
</book></ListOfBookInfo>
</RowIDWithListOfBooks>
</ListOfRowIDWithListOfBooks>

望ましい出力:

<?xml version="1.0"?>
<ListOfRowIDWithListOfBooks xmlns:bpws="http://schemas.xmlsoap.org/ws/2003/03/business-process/">
<RowIDWithListOfBooks>
<ListOfBookInfo>
<book>
<BookType>Brand</BookType>
<BookName>jon</BookName>
</book>
<CD>
<CDType>Country</CDType>
<CDName>MaxStar</CDName>
</CD>
</ListOfBookInfo>
</RowIDWithListOfBooks>
</ListOfRowIDWithListOfBooks>
4

1 に答える 1