Смекни!
smekni.com

Учебник php (стр. 8 из 26)

$email = "mailname@mail.ru";$domain = strstr($email, "@");// или$domain = strstr($email, ord("@"))echo $domain;// выведет @mail.ru

stristr
Нахождение первого вхождения подстроки, не учитывая регистр.

Синтаксис :
string stristr(string haystack, string needle)

Функция stristr() возвращает участок строки, заданной в параметре haystack, начиная с первого фрагмента, указанного в параметре needle и до конца.
В случае неудачи возвращает false.
Данная функция нечувствительна к регистру.
В случае, если needle не является строкой, то значение преобразуется в целое и используется как код искомого символа.

strrchr
Поиск последнего вхождения подстроки.

Синтаксис :
string strrchr(string haystack, string needle)

Функция strrchr() возвращает участок строки, заданной в параметре haystack, начиная с последнего фрагмента, указанного в параметре needle и до конца.
В случае неудачи возвращает false.
Данная функция чувствительна к регистру.
В случае, если needle не является строкой, то значение преобразуется в целое и используется как код искомого символа.

// получим последний каталог в $PATH$dir = substr(strrchr($PATH, ":"), 1);// а здесь получим все после последнего перевода строки$text = "text 1\nText2\nText3";echo substr(strrchr($text, 10), 1);

strpos
Находит позицию первого вхождения подстроки в заданной строке.

Синтаксис :
int strpos(string where, string what [, int fromwhere])

Функция strpos() пытается найти в строке were подстроку what и в случае успеха возвращает позицию (индекс) этой подстроки в строке. Первый символ строки имеет индекс 0. Необязательный параметр fromwhere можно задавать, если поиск нужно вести не с начало строки, а с какой-то другой позиции. В этом случае следует эту позицию передать в fromwhere. Если подстроку не удалось найти, функция возвращает false.
Если параметр what не строка, в этом случает его значение преобразуется в целое и используется как код искомого символа.

if(strpos($text, "a")===false) echo "Ненайдено!";// Проверка: три знака равенства

strrpos
Находит в заданной строке последнюю позицию, в которой находится заданный фрагмент.

Синтаксис :
int strrpos(string where, string what)

Данная функция ищет в строке where последнюю позицию, в которой встречался символ what (если what - строка из нескольких символов, то выявляется только первый из них, остальные не играют никакой роли).
Если искомый символ стоит первый в строке или его вообще нет, функция возвратит 0.
В случае, если искомый символ не найден, возвращает false.

substr_count
Находит количество вхождений фрагмента в строку.

Синтаксис :
int substr_count(string where, string what)

Функция substr_count() возвращает число фрагментов what, присутствующих в строке where.

echo substr_count("www.spravkaweb.ru", ".");// Выведет 3

strspn
Определяет присутствие начальных символов в строке.

Синтаксис :
int strspn(string str1, string str2)

Функция strspn() возвращает длину начального фрагмента строки str1, состоящего полностью из символов, которые есть в строке str2.

echo strspn("www.spravkaweb.ru", "abc");// Выведет 3

strcspn
Определяет отсутствие начальных символов в строке.

Синтаксис :
int strcspn(string str1, string str2)

Функция strspn() возвращает длину начального фрагмента строки str1, состоящего полностью не из символов, которые есть в строке str2.

Функции сравнения

strcmp
Сравнивает строки.

Синтаксис :
int strcmp(string str1, string str2)

Эта функция сравнивает две строки посимвольно (точнее, бобайтово) и возвращает:
0 - если строки полностью совпадают;
-1 - если строка str1 лексикографически меньше str2;
1 - если, наоборот, str1 "больше" str2.
Так как сравнение идет побайтово, то регистр символов влияет на результаты сравнений.

strncmp
Сравнивает начала строк.

Синтаксис :
int strncmp(string str1, string str2, int len)

Эта функция отличается от strcmp() тем, что сравнивает не все слово целиком, а первые len байтов. В случае, если len меньше длины наименьшей из строк, то строки сравниваются целиком.
Эта функция сравнивает две строки посимвольно (точнее, бобайтово) и возвращает:
0 - если строки полностью совпадают;
-1 - если строка str1 лексикографически меньше str2;
1 - если, наоборот, str1 "больше" str2.
Так как сравнение идет побайтово, то регистр символов влияет на результаты сравнений.

strcasecmp
Сравнивает строки без учета регистра.

Синтаксис :
int strcasecmp(string str1, string str2)

То же самое, что и strcmp(), только при работе не учитывается регистр букв.

$str1 = "Привет!";$str2 = "привет!";if(!strcesecmp($str1, $str2))echo "$str1 == $str2 при сравнении строк без учета регистра";

strncasecmp
Сравнивает начала строк без учета регистра.

Синтаксис :
int strncasecmp(string str1, string str2, int len)

Функция strncasecmp() является комбинацией функций strcasecmp() и strncmp().

strnatcmp
Производит "естественное" сравнение строк.

Синтаксис :
int strnatcmp(string str1, string str2)

Данная функция имитирует сравнение строк, которое использовал бы человек.

$arr1 = $arr2 = array("img12.png", "img10.png", "img2.png", "img1.png");echo "Обычнаясортировка\n";usort($arr1, "strcmp");print_r($arr1);echo "\nЕстенственная сортировка\n";usort($arr2, "strnatcmp");print_r($arr2);

Данный скприпт выведет следующее:

Обычная сортировкаArray( [0] => img1.png [1] => img10.png [2] => img12.png[3] => img2.png) Естественная сортировкаArray( [0] => img1.png [1] => img2.png [2] => img10.png [3] => img12.png)

strnatcasecmp
Производит "естественное" сравнение строк без учета регистра.

Синтаксис :
int strnatcasecmp(string str1, string str2)

То же, что и strnatcmp(), только игнорирует регистр.

similar_text
Производит определение схожести двух строк.

Синтаксис :
int similar_text(string firsrt, string second [, double percent])

Функция similar_text() вычисляет схожесть двух строк по алгоритму, описанному Оливером (Oliver [1993]). Но вместо стека (как в псевдокоде Оливера) она использует рекурсивные вызовы.
Сложность алгоритма делает функцию медленной, и ее скорость пропорциональна (N^3), где N - длина наибольшей строки.
Функция возвращает число символов, совпавших в обеих строках. При передаче по ссылке третьего необязательного параметра в нем сохраняется процент совпадения строк.

levenshtein
Определение различия Левенштейна двух строк.

Синтаксис :
int levenshtein(string str1, string str2)
int levenshtein(string str1, string str2, int cost_ins, int cost_rep, int cost_del)
int levenshtein(string str1, string str2, function cost)

"Различие Левенштейна" - это минимальное чило символов, которое требовалось бы заменить, вставить или удалить для того, чтобы превратить строку str1 в str2. Сложность алгоритма пропорциональна произведению длин строк str1 и str2, что делает функцию более быстродействующей, чем similar_text().

Первая форма функции возвращает число необходимых операций над символами строк для трансформации str1 в str2.

Вторая форама имеет три дополнительных параметра: стоимость операции вставки, замены и удаления, что делает ее более адаптированной для вычисления, но при этом менее быстродействующей. Возвращается интегральный показатель сложности трансформации.

Третий вариант позволяет указать функцию, используемую для расчета сложности трансформации. Функция cost вызывается со следующими аргументами:

· применяемая операция (вставить, изменить, удалить): "I*quot;, "R", "D";

· фактический символ первой строки

· фактический символ второй строки

· позиция строки 1

· позиция строки 2

· оставшаяся длина строки 1

· оставшаяся длина строки 2

Вызываемая функция должна будет возвратить стоимость этой операции.
Если длина одной из строк более 255 символов, функция levenshtein() возвращает -1, но такая длина более чем достаточна.

Форматирование и вывод строк

print
Выводит строку, значение переменной или выражение.

Синтаксис :
print(string arg)

Функция print() выводит аргумент arg, в качестве которого может быть переменная или выражение.

echo
Производит вывод одного или нескольких значений.

Синтаксис :
echo(string arg1, string [argn]...)

Функция echo() выводит значения перечисленных параметров.
echo() - фактически языковая конструкция, поэтому для нее не обязательны скобки, даже если используется несколько аргументов.

echo "Перенос на следующую строку,имеющийся в коде, сохраняетсяи используется при выводе"."чтобы избежать этого используйте"."оператор конкатенации";

printf
Вывод отформатированной строки.

Синтаксис :
int printf(string format [, mixed args, ...]);

Делает то же самое, что и sprintf(), только результирующая строка не возвращается, а направляется в браузер пользователя.

sprintf
Производит форматирование строки с подстановкой переменных.

Синтаксис : sprintf($format [,args, ...])

Эта функция возвращает строку, составленную на основе строки форматирования, содержащей некоторые специальные символы, которые будут впоследствии заменены на значения соответствующих переменных из списка аргументов.

Строка форматирования $format может включать в себя команды форматирования, предваренные символом %. Все остальные символы копируются в выходную строку как есть. Каждый спецификатор формата (то есть, символ % и следующие за ним команды) соответствуют одному, и только одному параметру, указанному после параметра $format. Если же нужно поместить в текст % как обычный символ, необходимо его удвоить:

echo sprintf("The percentage was %d%%",$percentage);

Каждый спецификатор формата включает максимум пять элементов (в порядке их следования после символа %):

· Необязательный спецификатор размера поля, который указывает, сколько символов будет отведено под выводимую величину. В качестве символов-заполнителей (если значение имеет меньший размер, чем размер поля для его вывода) может использоваться пробел или 0, по умолчанию подставляется пробел. Можно задать любой другой символ-наполнитьел, если указать его в строке форматирования, предварив фпострофом.