- ctype_alnum
- Список параметров
- Возвращаемые значения
- Примеры
- Смотрите также
- User Contributed Notes 4 notes
- Php каждому символу буква
- Получить символ строки кириллица utf-8
- Как получить символ строки кириллица utf-8
- Получить символ строки кириллица utf-8 -> mb_substr
- Замена регистра в строках PHP
- Проверка, является ли буква прописной или строчной
- Первая заглавная буква
- Для UTF-8:
- Первая строчная
- Для UTF-8:
- Все заглавные буквы
- Для UTF-8:
- Все строчные буквы
- Для UTF-8:
- Заглавная буква в каждом слове
- Для UTF-8:
- Инверсия регистра
- Комментарии 1
ctype_alnum
Проверяет, все ли символы в переданной строке text являются буквенно-цифровыми.
Список параметров
Замечание:
Если передано целое число ( int ) в диапазоне между -128 и 255 включительно, то оно будет обработано как ASCII-код одного символа (к отрицательным значениям будет прибавлено 256 для возможности представления символов из расширенного диапазона ASCII). Любое другое целое число будет обработано как строка, содержащая десятичные цифры этого числа.
Начиная с PHP 8.1.0, передача нестроковых аргументов устарела. В будущем аргумент будет интерпретироваться как строка вместо кода ASCII. В зависимости от предполагаемого поведения аргумент должен быть приведён к строке ( string ) или должен быть сделан явный вызов функции chr() .
Возвращаемые значения
Возвращает true , если каждый символ в строке text является буквой или цифрой, иначе возвращается false . При вызове с пустой строкой результатом всегда будет false .
Примеры
Пример #1 Пример использования ctype_alnum() (с использованием локали по умолчанию)
$strings = array( ‘AbCd1zyZ9’ , ‘foo!#$bar’ );
foreach ( $strings as $testcase ) if ( ctype_alnum ( $testcase )) echo «Строка $testcase состоит только из букв и цифр.\n» ;
> else echo «Строка $testcase не состоит только из букв и цифр.\n» ;
>
>
?>?php
Результат выполнения данного примера:
Строка AbCd1zyZ9 состоит только из букв и цифр. Строка foo!#$bar не состоит только из букв и цифр.
Смотрите также
- ctype_alpha() — Проверяет наличие буквенных символов
- ctype_digit() — Проверяет наличие цифровых символов в строке
- setlocale() — Устанавливает настройки локали
User Contributed Notes 4 notes
ctype_alnum() is a godsend for quick and easy username/data filtering when used in conjunction with str_replace().
Let’s say your usernames have dash(-) and underscore(_) allowable and alphanumeric digits as well.
Instead of a regex you can trade a bit of performance for simplicity:
$sUser = ‘my_username01’ ;
$aValid = array( ‘-‘ , ‘_’ );
if(! ctype_alnum ( str_replace ( $aValid , » , $sUser ))) <
echo ‘Your username is not properly formatted.’ ;
>
?>
It is also important to note that the behavior of `ctype_alnum` differs according to the operating system. For UNIX-based operating system, if you pass a value that is not a string (or an overloaded object), independently of the value, it will always result in false. However, if we do the same on Windows, using, for example, -1 as literal (a minus and a number greater than 0), we’ll have true as result.
Quicktip: If ctype is not enabled by default on your server, replace ctype_alnum($var) with preg_match(‘/^[a-zA-Z0-9]+$/’, $var).
Just for the record, Gentoo doesn’t include this function by default. You’ll have to recompile PHP with the «ctype» USE flag.
Php каждому символу буква
Для иллюстрации получения символа строки нам потребуется какая-то строка:
Опять предположим, что нам потребуется 5 символ нашей строки, поступаем как с массивом и выедем определенный символ строки с помощью echo:
Результат получения и вывода определенного символа строки:
Если вы были внимательны, то должны были обратить внимание, на то, что буква выводится 6 по счету. а нам нужна была 5. дело в том, что здесь работает тоже правило, что и с массивом. счет начинается с нуля. и [0] это 1. как бы странно это не звучало! смайлы , возможно, что через несколько лет вы привыкните, а может и нет. смайлы
Получить символ строки кириллица utf-8
В свое время я пересел на кодировку utf-8, почему!? Да просто как-то притомился с вылезанием постоянных крокозябер!
Мы победили крокозябры, но! Проблема в том. что php(редиска, это не такая уж большая проблема. если вы знаете, что делать) не очень любит кириллицу в кодировке utf-8, у нас будет отдельная страница в utf-8 не работает, поэтому не будем растекаться по древу.
Как получить символ строки кириллица utf-8
Для иллюстрации получения символа строки в кириллице, нам потребуется эта самая строка на кириллице.
Если мы проделаем тоже, что было применено в выше идущем пункте.
Как я не пытался различными способами решить именно такой способ получения символа строки, увы я не смог решить этот ребус! Но. разве это когда-то нас останавливало!? У нас есть для этого функция, которые в состоянии получить определенный символ строки. получим. пусть это будет первый элемент строки:
Нам нужно перекодировать строку в windows-1251 применяем функцию substr, третьим значением ставим тот символ строки который хотим получить, и третьим шагом возвращаем кодировку строки.
$string_1 = ‘Привет мир!’;
$stroka = iconv(‘UTF-8′,’windows-1251’,$string_1 ); //Меняем кодировку на windows-1251
$stroka = substr($stroka , 0 , 1); //Получаем требуемый(1) символ строки
$stroka = iconv(‘windows-1251′,’UTF-8’,$stroka ); //Меняем кодировку на windows-1251
Результат получения определенного символа строки:
Получить символ строки кириллица utf-8 -> mb_substr
Вообще, если у вас кириллица, то должна работать функция mb_substr, не то, чтобы, я с утра до вечера пользуюсь функциями с mb, но сколько бы я не использовал их, то всегда с ними что-то не то.
если мы сейчас применим функцию mb_substr:
Для того, чтобы данная функция получила определенный символ строки, то нужно объявить кодировку внутри скрипта.
Результат получения символа строки с помощью mb_substr
Замена регистра в строках PHP
Список PHP-функций для изменения регистра символов в строках и примеры их использования.
Проверка, является ли буква прописной или строчной
Функция ctype_upper($string) – определяет, являются ли все буквы в строке в верхнем регистре.
$str = 'Ы'; if (ctype_upper($str)) < echo 'Заглавная'; >else
Вариант для кириллицы в кодировке UTF-8:
$str = 'Ы'; if (mb_strtolower($str) !== $str) < echo 'Заглавная'; >else < echo 'строчная'; >// Выведется «Заглавная»
Пример определения регистра для первой буквы в строке:
$text = 'Привет мир!'; $chr = mb_substr($text, 0, 1); if (mb_strtolower($chr) !== $chr) < echo 'Заглавная'; >else < echo 'строчная'; >// Выведется «Заглавная»
Первая заглавная буква
ucfirst($string) — преобразует первый символ строки в верхний регистр.
$text = 'привет Мир!'; echo ucfirst($text);
Для UTF-8:
if(!function_exists('mb_ucfirst')) < function mb_ucfirst($str) < $fc = mb_strtoupper(mb_substr($str, 0, 1)); return $fc . mb_substr($str, 1); >> $text = 'привет Мир!'; echo mb_ucfirst($text); // Привет Мир!
Первая строчная
ucfirst($string) — преобразует первый символ строки в верхний регистр.
$text = 'Привет Мир!'; echo lcfirst($text);
Для UTF-8:
if(!function_exists('mb_lcfirst')) < function mb_lcfirst($str) < $fc = mb_strtolower(mb_substr($str, 0, 1)); return $fc . mb_substr($str, 1); >> $text = 'Привет Мир!'; echo mb_lcfirst($text); // привет Мир!
Все заглавные буквы
Для UTF-8:
$text = 'привет Мир!'; echo mb_strtoupper($text); // ПРИВЕТ МИР!
Все строчные буквы
$text = 'Привет Мир!'; echo strtolower($text);
Для UTF-8:
$text = 'Привет Мир!'; echo mb_strtolower($text); // привет мир!
Заглавная буква в каждом слове
$text = 'привет мир!'; echo ucwords($text);
Для UTF-8:
if(!function_exists('mb_ucwords')) < function mb_ucwords($str) < $str = mb_convert_case($str, MB_CASE_TITLE, "UTF-8"); return ($str); >> $text = 'привет мир!'; echo mb_ucwords($text); // Привет Мир!
Инверсия регистра
function mb_flip_case($string) < $characters = preg_split('/(?$char) < if (mb_strtolower($char, "UTF-8") != $char) < $char = mb_strtolower($char, 'UTF-8'); >else < $char = mb_strtoupper($char, 'UTF-8'); >$characters[$key] = $char; > return implode('', $characters); > $text = 'Привет Мир!'; echo mb_flip_case($text); // пРИВЕТ мИР!
Комментарии 1
function invertCase($text)
$string = »;
/*
Решение №1
$mb_strlen = mb_strlen($text);
$i = $mb_strlen;
while ($i > 0) $i—;
$char = mb_substr($text, $i, 1);
$char = (mb_strtolower($char) === $char) ? mb_strtoupper($char) : mb_strtolower($char);
$string = $char.$string;
>
*/
// Решение №2
$arr = mb_str_split($text, 1);
foreach ($arr as $char) $char = (mb_strtolower($char) === $char) ? mb_strtoupper($char) : mb_strtolower($char);
$string .= $char;
>
return $string;
>
Авторизуйтесь, чтобы добавить комментарий.