{% else-1 %}
(копипаст).
Не так давно, я разговаривал о программировании, вёрстке и сайтостроении с одним знакомым, как всегда упомянул свой блог, и тут он мне говорит, что на моём блоге о PHP «ни слуху, ни духу». Честно, меня это задело. А ведь и правда, статей о скриптах на PHP, совсем нет. Поэтому я решил, что в ближайшее время, обязательно напишу какой-нибудь скрипт.
Поэтому я решил написать вот эту функцию, по склонению имён с указанием пола и падежа. Решил я назвать её smart_name(). Получилось немножко громоздко,
но… В функции имеется 12 массивов, мде… многовато, но всё-таки. 6 массивов для женских имён и 6 массивов для мужских. Первый массив — именительный падеж, второй — родительный, третий — дательный, четвёртый — винительный, пятый — творительный, шестой — предложный. Хочу заметить, что в массивах хранятся окончания имён. Имя, окончание которого отсутствует в базе, склоняться не будет, например мужское имя Вилли, или женское Лили. Также учтена особеность склонения имён с одинаковым окончанием -ия-, Анастасия и Лия будут склоняться по-разному. В общем хватит лишних слов, вот код функции:

                        
//склоняет имя, учитывая пол $s(1 - мужской, 0 - женский)
//падеж $p (1 - именительный; 2 - родительный; 3 - дательный; 4 - винительный; 5 - творительный; 6 - предложный)
function smart_name($name, $s, $p){
$f_end1 = array('ла','ка','ша','ра','ня','тя','на','га','ля','та','да','са','ия','дя','ся','ья','вь','ва','оя','за','ая','ма','фа','йа');
$f_end2 = array('лы','ки','ши','ры','ни','ти','ны','ги','ли','ты','ды','сы','ии','ди','си','ьи','ви','вы','ои','зы','аи','мы','фы','йи');
$f_end3 = array('ле','ке','ше','ре','не','те','не','ге','ле','те','де','се','ии','де','се','ье','ви','ве','ое','зе','ае','ме','фе','йе');
$f_end4 = array('лу','ку','шу','ру','ню','тю','ну','гу','лю','ту','ду','су','ию','дю','сю','ью','вь','ву','ою','зу','аю','му','фу','йю');
$f_end5 = array('лой','кой','шей','рой','ней','тей','ной','гой','лей','той','дой','сой','ией','дей','сей','ьей','вью','вой','оей','зой','аей','мой','фой','йей');
$f_end6 = array('ле','ке','ше','ре','не','те','не','ге','ле','те','де','се','ии','де','се','ье','ви','ве','ое','зе','ае','ме','фе','йе');
$m_end1 = array('ма','ас','ша','ей','ня','ик','ва','рь','ля','лл','им','кс','тя','ад','ан','ат','ий','ха','ём','ем','ян','ис','ай','ир','ав','эн','ен','ег','ил','еб','ев','ам','он','ид','рп','ин','ор','ст','от','иф','кс','ар','та','нт','рх','тр','ум','ов','рк','ьф','ед','ьд','кт','ьм','яс','их','ет','ия','ья','ак','рт','рл');
$m_end2 = array('мы','аса','ши','ея','ни','ика','вы','ря','ли','лла','има','кса','ти','ада','ана','ата','ия','хи','ёма','ема','яна','иса','ая','ира','ава','эна','ена','ега','ила','еба','ьва','ама','она','ида','рпа','ина','ора','ста','ота','ифа','кса','ара','ты','нта','рха','тра','ума','ова','рка','ьфа','еда','ьда','кта','ьма','яса','иха','ета','ия','ьи','ака','рта','рла');
$m_end3 = array('ме','асу','ше','ею','не','ику','ве','рю','ле','ллу','иму','ксу','те','аду','ану','ату','ию','хе','ёму','ему','яну','ису','аю','иру','аву','эну','ену','егу','илу','ебу','ьву','аму','ону','иду','рпу','ину','ору','сту','оту','ифу','ксу','ару','те','нту','рху','тру','уму','ову','рку','ьфу','еду','ьду','кту','ьму','ясу','иху','ету','ию','ье','аку','рту','рлу');
$m_end4 = array('му','аса','шу','ея','ню','ика','ву','ря','лю','лла','има','кса','тю','ада','ана','ата','ия','ху','ёму','ему','яна','иса','ая','ира','ава','эна','ена','ега','ила','еба','ьва','ама','она','ида','рпа','ина','ора','ста','ота','ифа','кса','ара','ту','нта','рха','тра','ума','ова','рка','ьфа','еда','ьда','кта','ьма','яса','иха','ета','ия','ью','ака','рта','рла');
$m_end5 = array('мой','аом','шей','еем','ней','иком','вой','рем','лей','ллом','има','ксом','тей','адом','аном','атом','ием','хой','ёмом','емом','яном','исом','аем','иром','авом','эном','еном','егом','илом','ебом','ьвом','амом','оном','идом','рпом','ином','ором','стом','отом','ифом','ксом','аром','той','нтом','рхом','тром','умом','овом','рком','ьфом','едом','ьдом','ктом','ьмом','ясом','ихом','етом','ием','ьёй','аком','ртом','рлом');
$m_end6 = array('ме','асе','ше','ее','не','ике','ве','ре','ле','лле','име','ксе','те','аде','ане','ате','ии','хе','ёме','еме','яне','исе','ае','ире','аве','эне','ене','еге','иле','ебе','ьве','аме','оне','иде','рпе','ине','оре','сте','оте','ифе','ксе','аре','те','нте','рхе','тре','уме','ове','рке','ьфе','еде','ьде','кте','ьме','ясе','ихе','ете','ие','ье','аке','рте','рле');
$name = strtolower($name);
$num = strlen($name);
$r = ucfirst($name);
$lch = $name{$num-2}.$name{$num-1};
if($s == 0) {
$amount = count($f_end1);
if(in_array($lch, $f_end1)) {
if($p == 2) {
for($i=0;$i<$amount;$i++)
($lch==$f_end1[$i])?$ch=$f_end2[$i]:0;
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if($p == 3) {
for($i=0;$i<$amount;$i++)
($lch==$f_end1[$i])?$ch=$f_end3[$i]:0;
(($lch=='ия')&&($num>3))?$ch='ии':0;
(($lch=='ия')&&($num<4))?$ch='ие':0;
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if($p == 4) {
for($i=0;$i<$amount;$i++)
($lch==$f_end1[$i])?$ch=$f_end3[$i]:0;
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if ($p == 5) {
for($i=0;$i<$amount;$i++)
($lch==$f_end1[$i])?$ch=$f_end3[$i]:0;
$name{$num} = $ch{2};
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if ($p == 6) {
for($i=0;$i<$amount;$i++)
($lch==$f_end1[$i])?$ch=$f_end3[$i]:0;
(($lch=='ия')&&($num>3))?$ch='ии':0;
(($lch=='ия')&&($num<4))?$ch='ие':0;
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
}
}
if ($s == 1) {
$amount = count($m_end1);
if(in_array($lch, $m_end1)) {
if ($p == 2) {
for($i=0;$i<$amount;$i++)
($lch==$m_end1[$i])?$ch=$m_end2[$i]:0;
$name{$num} = $ch{2};
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if ($p == 3) {
for($i=0;$i<$amount;$i++)
($lch==$m_end1[$i])?$ch=$m_end3[$i]:0;
$name{$num} = $ch{2};
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if ($p == 4) {
for($i=0;$i<$amount;$i++)
($lch==$m_end1[$i])?$ch=$m_end4[$i]:0;
$name{$num} = $ch{2};
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if ($p == 5) {
for($i=0;$i<$amount;$i++)
($lch==$m_end1[$i])?$ch=$m_end5[$i]:0;
$name{$num+1} = $ch{3};
$name{$num} = $ch{2};
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
if ($p == 6) {
for($i=0;$i<$amount;$i++)
($lch==$m_end1[$i])?$ch=$m_end6[$i]:0;
$name{$num} = $ch{2};
$name{$num-1} = $ch{1};
$name{$num-2} = $ch{0};
$r = ucfirst($name);
}
}
}
return $r;
}

Функция расчитана на склонение русских имён, если вдруг, я упустил какое-то имя, Вы можете самостоятельно добавить его. Для этого нужно во все 6 массивов добавить окончания этого имени.


После, я случаянно наткнулся на сервис Яндекса Склонятор. А после на функцию, которая поможет склонять имена, фамилии и даже некоторые ники и слова. Хороша она тем, что не требует указания рода, и можно подавать на склонение целую фразу, например ф.и.о. Курьян Станислав Олегович. Со своей задачей она справляется превосходно. Вот код функции:
function inflect($name) {
$url = 'http://export.yandex.ru/inflect.xml?name='.urlencode($name);
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_USERAGENT, 'Opera/9.80 (Windows NT 6.1; U; ru) Presto/2.6.30 Version/10.61');
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$result = curl_exec($curl);
curl_close($curl);
$cases = array();
preg_match_all('#\<inflection\s+case\=\"([0-9]+)\"\>(.*?)\<\/inflection\>#si', $result, $m);
if ( count($m[0]) ) {
foreach ($m[1] as $i => &$id) {
$cases[(int)$id] = $m[2][$i];
} unset ($id);
} else return null;
if (count($cases) > 1) return $cases;
else return false;
}

Как видите функция компактнее. Возвращает массив склонённых слов.
Для того, чтобы явно указать падеж, можно дописать ещё одну небольшую функцию s_name(), у которой в качестве входящих параметров выступает
склоняемое имя и падеж.
function s_name($name, $p) {
$cases = inflect($name);
if ($cases && count($cases) > 1) return iconv("UTF-8", "Windows-1251", $cases[$p]);
else return iconv("UTF-8", "Windows-1251", $name);
}

Функция возвращает склонённое имя в кодировке UTF-8, поэтому я использовал функцию iconv() для преобразования в CP1251.
5 46 0
0

Фотография
Victor * Верифицирован 41.38
• 21 мар 2014, 15:50


Витюшина зайка, :3

0

Нет фото
• 21 мар 2014, 15:48


Лллыкуня! =*******

0

Фотография
Victor * Верифицирован 41.38
• 19 окт 2013, 21:19


Кидорас, еблан, я не занимаюсь копипастом.

0

Нет фото
• 19 окт 2013, 21:10


И этот код будет в твоей соцке? *

0

Нет фото
• 19 окт 2013, 02:21


А про вторую функцию и вправду можно сказать ГК,тк парсить XML регулярками не есть гуд