Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Помогите с разобраться регуляркой

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
Korsand
Отправлено: 08 Апреля, 2013 - 15:55:16
Post Id



Гость


Покинул форум
Сообщений всего: 70
Дата рег-ции: Февр. 2013  
Откуда: UA Donbass


Помог: 0 раз(а)




Привет. Помогите разобраться с регуляркой. Имеется вот такая PHPшка с регуляркой:
PHP:
скопировать код в буфер обмена
  1. <?PHP
  2. require_once('sql.php');
  3.  
  4.     $phone = strip_tags($_GET['phone']);
  5.     $country_code = preg_replace('/(^(380|7|44|1|49)\d{7}/','$1', $phone);
  6.        
  7.     $GLOBALS['MySQL']->res("INSERT INTO `tablica_01` SET `phone` = '{$phone}', `country_code` = '{$country_code}'");
  8. ?>

Оно работает, но имеются косяки. А именно: если номер телефона, который я получаю в запросе, не содержит перечисленный в регулярке код страны, то в ячейку таблицы «country_code» вноситься полностью телефонный номер, а мне этого не нужно. А хочется, что бы было как-то так: если код страны в регулярке совпал с кодом страны в телефоне, в «country_code» вноситься код страны, а если совпадений не найдено – то в «country_code» вноситься, например такое значение «0000». Вот подскажите, как это сделать, чего тут нужно дописать?

И ещё, как сделать так, что бы регулярка с начало проверяла что телефон содержит минимум 11 цифр, а только потом сопоставляла (выдирала) тел.код? Потому что сейчас у меня получается так, что с начало сопоставляется тел.код, а только потом после него отсчитывается 7 цифр. И выходит, что если тел.код «1», то общее кол-во цифр в номере должно быть не менее 8-ми, а если код «380», то общее кол-во цифр не менее 10-ти.

Буду весьма благодарен за помощь!

(Отредактировано автором: 09 Апреля, 2013 - 01:08:57)

 
 Top
Korsand
Отправлено: 09 Апреля, 2013 - 01:40:12
Post Id



Гость


Покинул форум
Сообщений всего: 70
Дата рег-ции: Февр. 2013  
Откуда: UA Donbass


Помог: 0 раз(а)




Выход кажись найден, и код даже работоспособен. Улыбка
Мой кодик: (Отобразить)

Сделал через preg_match. Типа, если в телефоне упоминается известный нам код страны, то вставляем этот код через replace, ну а если сходство не найдено - вставляем "UNKNOWN".

Но меня терзают смутные сомнения! Это же я тут, на форуме, указал в примере всего несколько кодов стран, а в реалии - у меня их чуть больше двухсот пятидесяти. И получается так, что я буду использовать две двухэтажные регулярки. Я от одной в шоке, а тут я вынужден вторую такую же влепить, нифига себе! Не понял И вот думаю, а нельзя ли чего-то переделать, что б обойтись одной? Может есть у кого-нибудь мысли по этому поводу?
 
 Top
Korsand
Отправлено: 15 Апреля, 2013 - 17:32:06
Post Id



Гость


Покинул форум
Сообщений всего: 70
Дата рег-ции: Февр. 2013  
Откуда: UA Donbass


Помог: 0 раз(а)




Задача давно решена и забыта. Но мало ли, может кому пригодиться:
PHP:
скопировать код в буфер обмена
  1. <?PHP
  2.     include('config_db.php');
  3.  
  4.     $phone = strip_tags($_GET['phone']);
  5.     $country_code = preg_replace('/^(380|7|44|1|49)\d{7,}/','$1', $phone);     
  6.        
  7.     if ($country_code == $phone) {
  8.         mysql_query('INSERT INTO `tablica_01` (`phone`, `country_code`) VALUES ("'.$phone.'", "UNKNOWN")');
  9.     }
  10.     else{
  11.         mysql_query('INSERT INTO `tablica_01` (`phone`, `country_code`) VALUES ("'.$phone.'", "'.$country_code.'")');
  12.     }
  13. ?>

Тут в регулярке, я указал только малую часть тел.кодов. В реалии, у меня их около двухсот пятидесяти.

(Отредактировано автором: 15 Апреля, 2013 - 17:39:17)

 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Регулярные выражения »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB