А вот результат:
<HTML>
<HEAD>
<TITLE>
Length of Planet Names
</TITLE>
</HEAD>
<BODY>
<H1>
Length of Planet Names
</H1>
Mercury is 7 characters long.
<BR>
Venus is 5 characters long.
<BR>
Earth is 5 characters long.
<BR>
</BODY>
</HTML>
Этот результирующий документ показан на рис. 8.2.
Рис. 8.2. Определение длины строк в XSLT
substring()
Функция substring возвращает подстроку переданной ей строки. Функция применяется следующим образом:
string substring(source-string, start-position, number-of-characters?)
Функция принимает параметры source-string (исходная строка), start-position (начальная позиция) и необязательный параметр number-of-characters (количество символов). Функция возвращает подстроку исходной строки с начальной позиции и до указанного количества символов или до конца строки, если это количество не задано.
Функция substring — одна из трех функций, оперирующих с подстроками: substring-before, возвращающая строку перед найденной подстрокой, сама substring, возвращающая заданную подстроку, и substring-after, возвращающая строку после найденной подстроки. В следующем примере (листинг 8.9) задействованы все три функции: в этом случае я разбил название планеты Меркурий (Mercury) на три подстроки — «Mer», «c» и «ury» — и затем объединил их снова. Вот как это можно сделать при помощи трех рассматриваемых функций (дополнительная информация о substring-before и substring-after приведена в следующих двух разделах).
Листинг 8.9. Применение функций substring-before, substring и substring-after<?xml version="1.0"?>
<xsclass="underline" stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsclass="underline" template match="/PLANETS">
<HTML>
<HEAD>
<TITLE>
Planetary Information
</TITLE>
</HEAD>
<BODY>
<H1>
Planetary Information
</H1>
<xsclass="underline" apply-templates/>
</BODY>
</HTML>
</xsclass="underline" template>
<xsclass="underline" template match="PLANET">
<xsclass="underline" if test="NAME='Mercury'">
The first planet is
<xsclass="underline" value-of select="concat(substring-before(NAME, 'с'),
substring(NAME, 4, 1), substring-after(NAME, 'c'))"/>.
<BR/>
</xsclass="underline" if>
</xsclass="underline" template>
<xsclass="underline" template match="*">
</xsclass="underline" template>
</xsclass="underline" stylesheet>
Вот результирующий документ, созданный этим преобразованием:
<HTML>
<HEAD>
<TITLE>
Planetary Information
</TITLE>
</HEAD>
<BODY>
<H1>
Planetary Information
</H1>
The first planet is Mercury.
<BR>
</BODY>
</HTML>
substring-after()
Функция substring-after возвращает подстроку, которая следует за найденной строкой. В эту функцию передается строка, подстрока, которую нужно найти внутри строки, — и функция возвращает подстроку, расположенную после совпадающей части строки, если она была найдена; иначе функция возвращает пустую строку. Функция применяется следующим образом:
string substring-after(string, string-to-match)
substring-before()
В функцию substring-before передается строка, подстрока, которую нужно найти внутри строки, и функция возвращает подстроку, расположенную перед совпадающей частью строки, если она была найдена; иначе функция возвращает пустую строку. Функция применяется следующим образом:
string substring-before(string, string-to-match)
В разделе substring() приведен пример применения функций substring-before, substring и substring-after.
translate()
Функция translate служит для перевода или замены определенных символов. (Эта функция во многом похожа на операцию tr в Perl, если вы знакомы с операциями.) В функцию передаются две строки: одна задает список символов поиска, вторая задает список символов, которыми нужно заменить найденные символы. Функция применяется следующим образом:
string translate(string, from-characters, to-characters)
Например, если третий символ из from-characters будет найден в string, то третий символ из to-characters заменит его в результирующей строке. В следующем примере такая функция translate
translate("steve-starpowder.com", "-", "@")
возвратит результирующую строку «steve@starpowder.com».
В этом примере я просто привожу строку к нижнему регистру:
translate("XSLT", "ABCDEFGHIJKLMNOPQRSTUVWXYZ", "abcdefghijklmnopqrstuvwxyz")
Функции XPath для работы с числами
В XPath имеются следующие функции для работы с числами:
• ceiling(). Возвращает наименьшее целое, большее переданного функции числа,
• floor(). Возвращает наибольшее целое, меньшее переданного функции числа;
• number(). Приводит переданный ей параметр к числу;
• round(). Округляет переданное функции число до ближайшего целого;