za4me
@za4me
Человек

Более простое написание моего кода?

Всем добрый день. Учу регулярные выражения по данной статье.
Остановился на "Пример к главе". Суть самого регулярного выражения я понял, решил смоделировать ситуацию описанную в статье, остановился на таком решении.

$name = ["фамилия имя отчество", "фамилия и о", "фамилия и.о."];
foreach ($name as $value) {
	preg_match("/([^\s]+)\s+([^\s.])[^\s.]*(?:\s|\.)([^\s.])[^\s.]*/", $value, $array);
	$arr[] = $array[1].' '.$array[2].$array[3];
}
print_r($arr);

Может быть подскажете более гармоничное решение?

И еще пара вопросов:
Каким образом добавить пробел в строку не прибегая к вставке пробела между кавычками? К примеру табуляция вставляется \t, в регулярках пробел пишется как \s (надеюсь суть выразил понятно).
У меня вместо букв имени и отчества вопросы, пробовал выставлять разную кодировку, но к успеху не привело.
201d5aff557842fd96799a1ee6327729.png
  • Вопрос задан
  • 128 просмотров
Пригласить эксперта
Ответы на вопрос 1
VladimirAndreev
@VladimirAndreev
php web dev
если текст в unicode, то надо так: /^.*/u иначе будет именно так...
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
Ведисофт Екатеринбург
от 25 000 ₽
YCLIENTS Москва
от 200 000 до 350 000 ₽
Бюро Цифровых Технологий Санкт-Петербург
от 120 000 до 180 000 ₽
04 мая 2024, в 22:32
2000 руб./за проект
04 мая 2024, в 22:10
2001 руб./за проект
04 мая 2024, в 21:12
10000 руб./за проект