$in = '...your text...';
// never use "e"
$bad = preg_replace('/\&\#([0-9]+)\;/me', "((\\1>255)?(utf8_decode(code2utf(\\1))):('&#\\1;'))", $in);
// use callback instead
$good = preg_replace_callback(
'/\&\#([0-9]+)\;/m',
function ($m) {
if ($m[1] > 255) {
return utf8_decode(code2utf($m[1]));
}
return "&#${m[1]};";
},
$in
);
<?php
function translit($str) {
$rus = array('А', 'Б', 'В', 'Г', 'Д', 'Е', 'Ё', 'Ж', 'З', 'И', 'Й', 'К', 'Л', 'М', 'Н', 'О', 'П', 'Р', 'С', 'Т', 'У', 'Ф', 'Х', 'Ц', 'Ч', 'Ш', 'Щ', 'Ъ', 'Ы', 'Ь', 'Э', 'Ю', 'Я', 'а', 'б', 'в', 'г', 'д', 'е', 'ё', 'ж', 'з', 'и', 'й', 'к', 'л', 'м', 'н', 'о', 'п', 'р', 'с', 'т', 'у', 'ф', 'х', 'ц', 'ч', 'ш', 'щ', 'ъ', 'ы', 'ь', 'э', 'ю', 'я');
$lat = array('A', 'B', 'V', 'G', 'D', 'E', 'E', 'Gh', 'Z', 'I', 'Y', 'K', 'L', 'M', 'N', 'O', 'P', 'R', 'S', 'T', 'U', 'F', 'H', 'C', 'Ch', 'Sh', 'Sch', 'Y', 'Y', 'Y', 'E', 'Yu', 'Ya', 'a', 'b', 'v', 'g', 'd', 'e', 'e', 'gh', 'z', 'i', 'y', 'k', 'l', 'm', 'n', 'o', 'p', 'r', 's', 't', 'u', 'f', 'h', 'c', 'ch', 'sh', 'sch', 'y', 'y', 'y', 'e', 'yu', 'ya');
return str_replace($rus, $lat, $str);
}
echo translit("Всем привет!");
?>
встал вопрос как в нем работать с данными
слышал что есть какие-то провайдеры
Вообщем мне нужен некий класс который инкапсулирует работу с данными
и чтобы в дальнейшем использовать его методы в контроллерах
SELECT t.*
FROM твоятаблица t
INNER JOIN (
SELECT id
,(
CASE coalesce(field, '') WHEN '' THEN 0 ELSE 1 END +
CASE coalesce(field2, '') WHEN '' THEN 0 ELSE 1 END +
CASE coalesce(field3, '') WHEN '' THEN 0 ELSE 1 END +
CASE coalesce(field4, '') WHEN '' THEN 0 ELSE 1 END +
CASE coalesce(field5, '') WHEN '' THEN 0 ELSE 1 END +
CASE coalesce(field6, '') WHEN '' THEN 0 ELSE 1 END
) AS cnt
FROM твоятаблица
) AS a ON a.id = t.id AND a.cnt >= 2