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 :: preg_match_all и кодировка

 PHP.SU

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


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

> Без описания
dadli
Отправлено: 15 Ноября, 2011 - 00:24:50
Post Id



Посетитель


Покинул форум
Сообщений всего: 416
Дата рег-ции: Май 2011  
Откуда: тифилис


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




хочу посчитат на каком месте стоит в строке кажди подчерирование, для етого исползую preg_match_all() но сталкивался с проблемои с кодировкои

если в строке латинские букви то всо норм

PHP:
скопировать код в буфер обмена
  1. preg_match_all("#_#u","d_o_c_",$arr,PREG_OFFSET_CAPTURE);


то всо норм, получаем: 1, 3, 5

а если руские букви:

PHP:
скопировать код в буфер обмена
  1. preg_match_all("#_#u","д_о_к_",$arr,PREG_OFFSET_CAPTURE);


уже резултат такои 1, 5, 8 модификатор u, не помагает,

сушествует какоита способ исправит ето ?
 
 Top
illy
Отправлено: 15 Ноября, 2011 - 05:18:08
Post Id



Участник


Покинул форум
Сообщений всего: 1117
Дата рег-ции: Июль 2011  
Откуда: от верблюда)


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




PHP:
скопировать код в буфер обмена
  1. <?PHP
  2. $text="hf_ёжик_пыф_gj";
  3. $k='';
  4. for($n=0;$n!=strlen($text);$n++){
  5. if($text[$n]=='_'){ $k.=$n.','; }
  6. }
  7. echo rtrim($k,',');
  8. ?>

(Отредактировано автором: 15 Ноября, 2011 - 05:18:49)



-----
Всё гениальное - просто
И ещё проще, если ты - индиго
 
 Top
EuGen Администратор
Отправлено: 15 Ноября, 2011 - 08:41:33
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


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




PHP:
скопировать код в буфер обмена
  1. $rgData=array_keys(preg_split("//u","д_о_к_",-1, 1), '_');
  2. //var_dump($rgData);


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
ALEN
Отправлено: 15 Ноября, 2011 - 10:18:57
Post Id



Участник


Покинул форум
Сообщений всего: 1459
Дата рег-ции: Авг. 2008  
Откуда: Крым


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




модификатор u указывает на кодировку UTF-8 , а не на кириллицу.
 
 Top
dadli
Отправлено: 15 Ноября, 2011 - 13:15:46
Post Id



Посетитель


Покинул форум
Сообщений всего: 416
Дата рег-ции: Май 2011  
Откуда: тифилис


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




illy
но резултат из ваш варянта тоже не желателни Улыбка

EuGen
да так хотел, и даже формат полученного резултата так лучше, спасибо балшое.

ALEN
если модификатор u написано, ето значит что шаблон обрабативается как UTF-8 да, но почемуто в етом случе он с preg_match_all() не работал.

спасибо всем за ответах
 
 Top
snikers987
Отправлено: 15 Ноября, 2011 - 13:38:26
Post Id



Участник


Покинул форум
Сообщений всего: 1239
Дата рег-ции: Сент. 2011  
Откуда: Крым


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




все верно она посчитала, кириллический символ - 2 байта .



-----
Когда всматриваешься в тёмную бездну, учти, что кто-то может смотреть на тебя из неё...
 
My status
 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