Модуль:String/doc
Это страница документации Модуль:String.
![]() | Внимание! Это один из самых используемых модулей. |
![]() | Прежде чем вносить какие-либо изменения в данный модуль, просьба оттестировать их в /песочнице и проверить результат на странице с /контрольными примерами. Изменения могут быть внесены после этого в данный модуль всего одной правкой. |
Этот модуль предназначен для обеспечения доступа к основным строковым функциям.
Большая часть функций, имеющихся в модуле, может быть вызвана именованными, неименованными параметрами или обоими вариантами. Если используются именованные параметры, движок Mediawiki автоматически удаляет любые начальные или конечные пробелы из параметра. В зависимости от предполагаемого использования может быть предпочтительным либо сохранение, либо удаление таких пробелов. Экспериментировать с модулем можно на странице Модуль:String/песочница.
Глобальные параметры
Шаблон:code: | Если параметру присвоено значение Шаблон:code или Шаблон:code, вместо любого сообщения об ошибке выводится пустая строка. |
Шаблон:code: | В случае возникновения ошибки определяет название категории, в которую помещается страница с сообщением об ошибке. По умолчанию помещается в Шаблон:c. |
Шаблон:code: | Если параметру присвоено значение Шаблон:code или Шаблон:code, то в случае сообщения об ошибке страница не будет помещена в соответствующую категорию. |
subcount
Функция возвращает количество подстрок внутри строки.
- Использование
{{#invoke:String|subcount|исходная_строка|подстрока|true / false}}
- или
{{#invoke:String|subcount|s=исходная_строка|pattern=подстрока|plain=true / false}}
- Параметры
Шаблон:code: | Целевая строка, часть которой необходимо найти. |
Шаблон:code: | Строка, совпадение с которой необходимо найти в целевой строке. |
Шаблон:code: | Если параметру присвоено значение Шаблон:code, функция воспринимает заданную строку как регулярное выражение. По умолчанию — Шаблон:code. |
len
Функция возвращает длину целевой строки.
- Использование
{{#invoke:String|len|целевая_строка}}
- или
{{#invoke:String|len|s= целевая_строка }}
- Параметры
Шаблон:code: | Строка, длину которой необходимо найти. |
sub
Функция возвращает часть целевой стоки между указанными индексами (порядковыми номерами символов в целевой строке)
- Использование
{{#invoke:String|sub|целевая_строка|начальный_индекс|конечный_индекс}}
- или
{{#invoke:String|sub|s= целевая_строка |i= начальный_индекс |j= конечный_индекс }}
- Параметры
Шаблон:code: | Строка, часть которой необходимо вывести. |
Шаблон:code: | Порядковый номер символа, начиная с которого необходимо вывести строку. Значение по умолчанию — 1. |
Шаблон:code: | Порядковый номер символа, до которого необходимо вывести строку. Значение по умолчанию — порядковый номер последнего символа. |
Первому символу строки присваивается индекс Шаблон:code. Если параметрам Шаблон:code или Шаблон:code присвоено отрицательное значение, то оно распознается модулем как порядковый номер символа, отсчитываемый с конца строки. Другими словами, значение Шаблон:code распознается модулем как порядковый номер последнего символа в строке.
Если введённые индексы по модулю больше длины целевой строки, то выводится сообщение об ошибке.
sublength
С помощью этой функции реализован шаблон Шаблон:t, она сохраняется для поддержания его работоспособности.
match
Функция возвращает часть целевой строки, которая соответствует заданной строке.
- Использование
{{#invoke:String|match|исходная_строка|заданная_строка|начальный_индекс|номер_совпадения|true / false|значение_если_нет_совпадений}}
- или
{{#invoke:String|match|s= исходная_строка |pattern= заданная_строка |start= начальный_индекс|match= номер_совпадения|plain= true / false |nomatch= значение_если_нет_совпадений }}
- Параметры
Шаблон:code: | Целевая строка, часть которой необходимо найти. |
Шаблон:code: | Строка, совпадение с которой необходимо найти в целевой строке. |
Шаблон:code: | Порядковый номер символа, начиная с которого необходимо произвести поиск совпадения. По умолчанию — Шаблон:code. Если начиная с заданного символа совпадений не найдено, функция возвращает сообщение об ошибке. |
Шаблон:code: | В некоторых случаях может оказаться несколько совпадений с заданной строкой в одной целевой строке. Параметр задает номер совпадения, которое необходимо вывести. Если параметру присвоено отрицательное значение, то оно распознается модулем как порядковый номер совпадения, отсчитываемый с конца строки. Другими словами, значение Шаблон:code распознается модулем как порядковый номер последнего совпадения в строке. По умолчанию — 1. |
Шаблон:code: | Если параметру присвоено значение Шаблон:code, функция воспринимает заданную строку как обычный текст, а не регулярное выражение. По умолчанию — Шаблон:code. |
Шаблон:code: | Последовательность символов, выводимая строкой в случае отсутствия совпадений вместо сообщения об ошибке. |
Если введённый индекс по модулю больше длины целевой строки или совпадений найдено меньше, чем число, заданное в параметре Шаблон:code, то выводится сообщение об ошибке. Если добавить параметр Шаблон:code, то вместо любого из сообщений об ошибке будет возвращена пустая строка.
Подробнее о регулярных выражениях, используемых в Lua, см. Руководство по метасимволам.
pos
Функция возвращает один символ из целевой строки под заданным порядковым номером.
- Использование
{{#invoke:String|pos|целевая_строка|значение_индекса}}
- или
{{#invoke:String|pos|target= целевая_строка |pos= значение_индекса }}
- Параметры
Шаблон:code: | Строка, в которой производится поиск символа. |
Шаблон:code: | Порядковый номер возвращаемого символа |
Если параметру Шаблон:code присвоено отрицательное значение, то оно распознается модулем как порядковый номер символа, отсчитываемый с конца строки. Другими словами, значение Шаблон:code распознается модулем как порядковый номер последнего символа в строке.
Если заданный порядковый номер равен 0 или больше длины строки, функция возвращает сообщение об ошибке.
str_find
Эта фунция предназначена для поддержания функционирования шаблона Шаблон:t. Она сохраняется для того, чтобы поддерживать существующие шаблоны, но она крайне не рекомендуется для использования в новых шаблонах. Рекомендуется вместо неё использовать функцию Шаблон:code.
Возвращает порядковый номер символа, начиная с которого целевая строка, заданная параметром Шаблон:code совпадает со строкой в параметре Шаблон:code. Функция возвращает −1
, если совпадений между строками не найдено.
Важно: Если в параметре Шаблон:code не задана строка, либо отсутствует сам параметр, функция возвращает 1
, что, как правило, является полной неожиданностью для пользователей.
find
Функция позволяет выполнить поиск целевой строки в другой строке.
- Использование
{{#invoke:String|find|исходная_строка|целевая_строка|начальный_индекс|true / false}}
- или
{{#invoke:String|find|source= исходная_строка |target= целевая_строка |start= начальный_индекс|plain= true / false }}
- Параметры
Шаблон:code: | Строка, в которой ведется поиск целевой строки. |
Шаблон:code: | Целевая строка, которая ищется в другой строке. |
Шаблон:code: | Порядковый номер символа, начиная с которого ведется поиск совпадений. Значение по умолчанию — 1. |
Шаблон:code: | Если параметру присвоено значение Шаблон:code, функция воспринимает заданную строку как обычный текст, а не регулярное выражение. По умолчанию — Шаблон:code. |
Функция возвращает значение, большее либо равное значению параметра Шаблон:code. Если совпадений не найдено, функция возвращает 0
, если одна из строк пустая или не задана, функция также возвращает 0
.
replace
Функция позволяет заменить целевую строку в другой строке.
- Использование
{{#invoke:String|replace|исходная_строка|целевая_строка|заменяющая_строка|количество_замен|true / false}}
- или
{{#invoke:String|replace|source= исходная_строка |pattern= целевая_строка|replace= заменяющая_строка |count= количество_замен |plain= true / false }}
- Параметры
Шаблон:code: | Строка, в которой ведется поиск. |
Шаблон:code: | Строка, которая ищется в исходной строке. |
Шаблон:code: | Строка, заменяющая целевую. |
Шаблон:code: | Количество заменяемых совпадений; по умолчанию — все. |
Шаблон:code: | Если параметру присвоено значение Шаблон:code, функция воспринимает заданную строку как обычный текст, а не регулярное выражение. По умолчанию — Шаблон:code. |
rep
Функция возвращает строку, состоящую из повторений n раз исходной строки.
- Использование
{{#invoke:String|rep|строка|количество_повторов}}
- Параметры
Шаблон:code: | Строка, которую необходимо повторить n раз. |
Шаблон:code: | Количество повторов. |
- Пример
{{#invoke:String|rep|привет!|3}}
→ привет!привет!привет!