[XSL-LIST Mailing List Archive Home] [By Thread] [By Date] [Recent Entries] [Reply To This Message]

RE: Sorting Question: Muenchian method? Substring in K

Subject: RE: Sorting Question: Muenchian method? Substring in Key?
From: Thomas_M <Thomas_M@xxxxxxx>
Date: Mon, 30 Sep 2002 10:35:14 -0400
method substring
Thanks to all who responded. I understand Muenchian grouping much better
now. I think of <xsl:key> as creating a hash table, and generate-id() like a
kind of checksum() routine.

My remaining question is: how efficient is it? I assume the <xsl:key> is
fairly efficient because the pregenerated lookup table makes subsequent
lookups quick. However, the Muenchian grouping in my simple example resulted
in no less than five calls to substring(), four of which are inside one or
more levels of <for-each> iteration.

-- 
Mark Thomas                       |_|
Internet Systems Architect        -+-
User Technology Associates, Inc.   |
Thomas_M@xxxxxxx                  /-\


> -----Original Message-----
> From: Michael Kay [mailto:michael.h.kay@xxxxxxxxxxxx] 
> Sent: Friday, September 27, 2002 5:05 PM
> To: xsl-list@xxxxxxxxxxxxxxxxxxxxxx
> Subject: RE:  Sorting Question: Muenchian method? 
> Substring in Key?
> 
> 
> There are two main approaches to grouping:
> 
> (a) the "not(x = preceding::x)" method
> (b) the Muenchian method
> 
> Method (a) works only where the grouping key is the 
> string-value of a node; this is because it relies on the 
> special properties of "=" when comparing two node-sets. Where 
> the grouping key is anything else (e.g. the first character 
> of the string value), you need to use Muenchian grouping.
> 
> Michael Kay
> Software AG
> home: Michael.H.Kay@xxxxxxxxxxxx
> work: Michael.Kay@xxxxxxxxxxxxxx 
> 
> > -----Original Message-----
> > From: owner-xsl-list@xxxxxxxxxxxxxxxxxxxxxx
> > [mailto:owner-xsl-list@xxxxxxxxxxxxxxxxxxxxxx] On Behalf Of Thomas_M
> > Sent: 27 September 2002 16:27
> > To: 'xsl-list@xxxxxxxxxxxxxxxxxxxxxx'
> > Subject:  Sorting Question: Muenchian method? Substring in Key?
> > 
> > 
> > Hello. This is my first XSLT project. I'm having trouble with
> > grouping sorted items (seems to be a common theme). I have a 
> > XML file like this
> > (simplified):
> > 
> > <topics>
> >   <topic>Anteater</topic>
> >   <topic>Aardvark</topic>
> >   <topic>Beetle, Smaller European Elm Bark</topic>
> >   <topic>Beetle, American Burying</topic>
> >   <topic>Chimpanzee</topic>
> > </topics>
> > 
> > I would like the output to be sorted and grouped, with each
> > group getting a
> > heading:
> > 
> > A
> > Aardvark
> > Anteater
> > 
> > B
> > Beetle, American Burying
> > Beetle, Smaller European Elm Bark
> > 
> > C
> > Chimpanzee
> > 
> > The corresponding part of my XSL is below.
> > 
> >   <xsl:template match="topics">
> >    <table border="1">
> >       <xsl:for-each select="topic">
> >         <xsl:sort select="."/>
> >         <xsl:variable name="previndex" select="position()-1"/>
> >         <xsl:if test="not(substring(.,1,1)
> >                       = substring(/topics/topic[$previndex],1,1))">
> > 		<tr><th><xsl:value-of
> > select="substring(.,1,1)"/></th></tr>
> > 
> >         </xsl:if>
> >             <tr>
> >               <td><xsl:value-of select="."/></td>
> >             </tr>
> >       </xsl:for-each>
> >     </table>
> >   </xsl:template>
> > 
> > As you can see, I'm comparing an element in a sorted node-set
> > with a document-order node-set. This works only if the XML is 
> > pre-sorted. Is there a way to create the sorted node-set 
> > first, so that I can both traverse and use it in my test?
> > 
> > I have seen a few examples of the Muenchian method, and it
> > would seem this is another (perhaps better) way solve my 
> > problem. However, I've tried several times to implement it 
> > and can't seem to get it right (can you use a substring in a key?)
> > 
> > Thanks for any insight,
> > 
> > - Mark.
> > 
> > -- 
> > Mark Thomas                       |_|
> > Internet Systems Architect        -+-
> > User Technology Associates, Inc.   |
> > Thomas_M@xxxxxxx                  /-\
> > 
> > 
> > 
> > 
> >  XSL-List info and archive:  
> http://www.mulberrytech.com/xsl/xsl-list
> > 
> 
> 
>  XSL-List info 
> and archive:  http://www.mulberrytech.com/xsl/xsl-list
> 


 XSL-List info and archive:  http://www.mulberrytech.com/xsl/xsl-list


Current Thread

PURCHASE STYLUS STUDIO ONLINE TODAY!

Purchasing Stylus Studio from our online shop is Easy, Secure and Value Priced!

Buy Stylus Studio Now

Download The World's Best XML IDE!

Accelerate XML development with our award-winning XML IDE - Download a free trial today!

Don't miss another message! Subscribe to this list today.
Email
First Name
Last Name
Company
Subscribe in XML format
RSS 2.0
Atom 0.3
Site Map | Privacy Policy | Terms of Use | Trademarks
Free Stylus Studio XML Training:
W3C Member
Stylus Studio® and DataDirect XQuery ™are products from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2013 All Rights Reserved.