Примеры
normalize-space(' А - В - С ')
→ 'А-В-С'
normalize-space('А х9; В х9; С') > 'A B C'
string translate( string , string , string )
Функция translate
производит замену символов первого своего строкового аргумента, которые присутствуют во втором аргументе на соответствующие символы третьего аргумента.
Пример
translate('abcdefgh', 'aceg', 'ACEG')
→ 'AbCdEfGh'
Если некоторый символ повторяется во втором аргументе несколько раз, учитывается только первое его появление.
Пример
translate('abcdefgh', 'acaeaga', 'ACBECGD')
→ 'AbCdEfGh'
Если второй аргумент длиннее третьего, символы, для которых нет соответствующей замены, удаляются из строки.
Пример
translate('a b-c=d+e|f/g\h', 'aceg-=+|/\', 'ACEG')
→ 'AbCdEfGh'
Если третий аргумент длиннее второго, остаток строки игнорируется.
Пример
translate('abcdefgh', 'aceg', 'ACEGBDFH')
→ ' AbCdEfGh'
Функцию translate
можно использовать, например, для изменения регистра символов. Конечно, это будет работать только для тех языков, для которых такая функция будет записана, но и этого в большинстве случаев будет достаточно. В будущем предполагается включить в новые версии языка более мощные функции для работы с регистрами символов.
Пример
Для того чтобы изменять регистр слов русского языка, мы можем определить две переменные, lowercase
и uppercase
, которые будут содержать строчные и прописные символы основного русского алфавита (мы включили в него букву ё — строчную (" ё
") и прописную (" Ё
"), хотя в соответствии с Unicode она относится к расширениям). Мы также создадим два именованных шаблона, которые будут менять регистр символов строкового параметра str
. Для удобства использования мы вынесем определения переменных и шаблонов во внешний модуль ru.xsl
.
Листинг 6.6. Преобразование ru.xsl
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
name="uppercase"
select="concat('АБВГ',
'ДЕЁЖЗ',
'ИЙКЛ',
'МНОП',
'РСТУ',
'ФХЦЧ',
'ШЩЪЫ',
'ЬЭЮЯ')"/>
name="lowercase"
select="concat('абвг',
'деёжЗ',
'ийкл',
'мноп',
'рсту',
'фхцч',
'шщъы',
'ьэюя')"/>
Использовать этот модуль можно, включив или импортировав его в основное преобразование элементами xsl:include
или xsl:import
. После этого в основном преобразовании будут доступны переменные lowercase
и uppercase
, которые можно будет использовать в функции translate
и шаблоны с именами lower
и upper
.
Использовать функцию translate
с переменными lowercase
и uppercase
можно следующим образом:
translate('Дом', $uppercase, $lowercase)
→ 'дом'
translate('Дом', $lowercase, $uppercase)
→ 'ДОМ'
Именованные шаблоны можно вызывать элементом xsl:call-template
, передавая параметр при помощи xsl:with-param
. Например, следующий фрагмент шаблона
...
>
...
создаст в выходящем дереве текстовый узел со значением " дом
".
number last()
number position()
Функция last
возвращает текущий размер контекста — число, которое показывает, сколько узлов находится в обрабатываемом в данный момент множестве.
Функция position
возвращает позицию контекста — число, показывающее порядковый номер контекстного узла в обрабатываемом множестве.
Пример
В этом примере мы будем заменять все элементы элементами вида
...
где атрибут name
будет содержать имя, a position
— через дробь позицию элемента в контексте и размер контекста.
Листинг 6.7. Входящий документ
<���а>
Листинг 6.8. Преобразование
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
Листинг 6.9. Выходящий документ
Отметим, что если бы мы не удаляли лишние пробельные символы во входящем документе при помощи элемента xsl:strip-space
, в контексте преобразования учитывались бы также и текстовые узлы, которые им соответствуют. Выходящий документ без этого элемента имел бы следующий вид:
number count( node-set )
Функция count
возвращает число узлов, которое входит во множество, переданное ей в качестве аргумента.
Читать дальше