我需要从XSLT文件创建一个html表,但只选择一组特定的节点。例如,在以下XML中,我希望选择routename包含fco-dxb的所有from和to子节点:
<?xml version="1.0" encoding="UTF-8"?>
<flights
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="flights.xsd">
<flight flightid="1">
<flightno>EK98</flightno>
<callsign>UAE98</callsign>
<airline>Emirates Airline</airline>
<plane planeid="1">
<name>Airbus A380-861</name>
<registereddate>07-06-10</registereddate>
</plane>
<registration>3A6-EDJ</registration>
<altitude height="feet">41000</altitude>
<speed ratio="mph">564</speed>
<distance unit="miles">erf</distance>
<route>
<routename>FCO-DXB</routename>
<from>
<iatacode>FCO</iatacode>
<airport>Fiumicino</airport>
<country>Italy</country>
<city>Rome</city>
<latitude>41.8044</latitude>
<longitude>12.2508</longitude>
</from>
<to>
<iatacode>DXB</iatacode>
<airport>Dubai Intl</airport>
<country>United Arab Emirates</country>
<city>Dubai</city>
<latitude>25.2528</latitude>
<longitude>55.3644</longitude>
</to>
</route>
<course bearing="degrees">154</course>
<journey>
<distance type="miles">2,697</distance>
<time>PT5H30M</time>
</journey>
</flight>
<flight flightid="2">
<flightno>BA283</flightno>
<callsign>BAW283</callsign>
<airline>British Airways</airline>
<plane planeid="2">
<name>Boeing 747-436</name>
<registereddate>06-12-97</registereddate>
</plane>
<registration>3A6-EDJ</registration>
<altitude height="feet">41000</altitude>
<speed ratio="mph">564</speed>
<distance unit="miles">erf</distance>
<route>
<routename>LHR-LAX</routename>
<from>
<iatacode>LHR</iatacode>
<airport>Heathrow</airport>
<country>England</country>
<city>London</city>
<latitude>51.4775</latitude>
<longitude>0.4614</longitude>
</from>
<to>
<iatacode>LAX</iatacode>
<airport>Los Angeles International</airport>
<country>United States of America</country>
<city>L.A</city>
<latitude>33.9471</latitude>
<longitude>-118.4082</longitude>
</to>
</route>
<course bearing="degrees">154</course>
<journey>
<distance type="miles">5,441 miles</distance>
<time>PT11H5M</time>
</journey>
</flight>
</flights>
并在表中输出,这是我在XSLT中的尝试:
<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html" omit-xml-declaration="yes" />
<xsl:template match="/">
<xsl:element name="html">
<xsl:element name="head">
<xsl:element name="title">flights</xsl:element>
</xsl:element>
<xsl:element name="body">
<xsl:element name="table"><xsl:attribute name="border">1</xsl:attribute>
<xsl:element name="tr">
<xsl:element name="td">
<xsl:element name="b">Title</xsl:element>
</xsl:element>
<xsl:element name="td">
<xsl:element name="b">Artist</xsl:element>
</xsl:element>
<xsl:element name="td">
<xsl:element name="b">Year</xsl:element>
</xsl:element>
</xsl:element>
<xsl:apply-templates select="flights/flight/route[contains(text(), 'FCO-DXB')]" />
</xsl:element>
</xsl:element>
</xsl:element>
</xsl:template>
<xsl:template match="from">
<xsl:element name="tr">
<xsl:element name="td"><xsl:value-of select="iatacode"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="airport"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="country"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="city"/></xsl:element>
</xsl:element>
</xsl:template>
<xsl:template match="to">
<xsl:element name="tr">
<xsl:element name="td"><xsl:value-of select="iatacode"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="airport"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="country"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="city"/></xsl:element>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
我的目标是最终弄清楚如何将参数传递给XSLT文件,所以我可以传递一个参数,而不是硬编码包含文本,但到目前为止我只想知道如何回答这个问题。
答案 0 :(得分:3)
您没有说是否可以有多个具有相同标识符的路由名称。如果有,它们应该显示在同一个表中或不同的表中(每个匹配一个)?
我在这里假设如果有多个具有相同标识符的路径名,则会在同一个表格中打印出来(如果这个假设不对,请更正我,我会相应更改代码)。
这是实现您想要实现的目标的一种方式:
<?xml version="1.0" encoding="utf-8" ?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html" omit-xml-declaration="yes" />
<xsl:param name="code"
select="'FCO-DXB'" />
<xsl:template match="/flights">
<html>
<head>
<title>flights</title>
</head>
<body>
<xsl:apply-templates select="flight/route[routename/. = $code]" />
</body>
</html>
</xsl:template>
<xsl:template match="route">
<table>
<tr>
<td><b>IATA Code</b></td>
<td><b>Airport</b></td>
<td><b>Country</b></td>
<td><b>City</b></td>
</tr>
<xsl:apply-templates select="*" />
</table>
</xsl:template>
<xsl:template match="from|to">
<tr><xsl:apply-templates select="*" /></tr>
</xsl:template>
<xsl:template match="iatacode|airport|country|city">
<td><xsl:value-of select="." /></td>
</xsl:template>
<xsl:template match="text()" />
</xsl:stylesheet>