PHPerKaigi 2025

Transliterator::create

transliterator_create

(PHP 5 >= 5.4.0, PHP 7, PHP 8, PECL intl >= 2.0.0)

Transliterator::create -- transliterator_createСоздать транслитератор

Описание

Объектно-ориентированный стиль

public static Transliterator::create(string $id, int $direction = Transliterator::FORWARD): ?Transliterator

Процедурный стиль

transliterator_create(string $id, int $direction = Transliterator::FORWARD): ?Transliterator

Открывает объект Transliterator по идентификатору.

Внимание

Функцию пока не задокументировали; для знакомства доступен только список аргументов.

Список параметров

id

Идентификатор. Список всех зарегистрированных идентификаторов транслитератора можно получить с помощью Transliterator::listIDs().

direction

Направление транслитерации. По умолчанию >Transliterator::FORWARD. Можно использовать Transliterator::REVERSE.

Возвращаемые значения

Возвращает объект Transliterator или null в случае возникновения ошибки.

Смотрите также

Добавить

Примечания пользователей 3 notes

up
2
Jan Kucha
4 years ago
If you want to go deeper into what is going on, read the ICU projects docs: http://userguide.icu-project.org/transforms/general

This API call is basically just wrapper around ICU Transliteration.
up
1
Baran Sakallolu
5 years ago
A good example of create for non latin languages is Turkish.

There both upper case I character and lowercase ı character which makes other strtolower kind of functions useless.

$text = "Iğdır";

echo Transliterator::create("tr-Lower")->transliterate($text);

will return the correct result ığdır, not iğdır .
up
0
Harry..de
4 years ago
// Translit each and every char to ASCII

$string = 'Москва́';
$string = Transliterator::create('Any-Latin; Latin-ASCII')->transliterate($string);

print $string;

// the result is "Moskva"
To Top