The document() Function and Sorting
Up to now, we’ve written a simple XML document that contains references to other XML documents, then we created a stylesheet that combines all those referenced XML documents into a single output document. That’s all well and good, but we’ll probably want to do more advanced things. For example, it might be useful to generate a document that lists all items ordered across all purchase orders. It might also be useful to sort all the purchase orders by the state to which they were shipped or by the last name of the customer. We’ll go through some of these scenarios to illustrate the design challenges we face when generating documents from multiple input files.
Our first challenge will be to generate a listing of all purchase
orders and sort them by state, then by city within state. This isn’t
terribly difficult; we’ll simply use the <xsl:sort>
element in conjunction with the document()
function. Here’s the heart of
our new stylesheet:
<?xml version="1.0"?>
<!-- masterdox2.xsl -->
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
...
<xsl:apply-templates
select="document(/report/po/@filename)/purchase-order">
<xsl:sort select="customer/address/state"/>
<xsl:sort select="customer/address/city"/>
</xsl:apply-templates>
Here we’re selecting all of the <purchase-order>
elements and sorting
them by the values of their <state>
and <city>
elements. Figure 8-2 shows our output document, sorted by the
value of the <state>
element ...
Get XSLT, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.