Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> regexp_replace 
:(
    Опции темы
DimW
Дата 2.2.2012, 17:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1330
Регистрация: 24.2.2005
Где: Орёл

Репутация: 23
Всего: 44



парни, регулярками занимаюсь пару дней, так что не пинайте  smile 

задача: удалить все слова состоящие из 'Д', 'Ш', 'ВЛ'.

рассуждаю так: слово должно начинаться с пробела затем должно идти слово 'Д' или 'Ш' или 'ВЛ' и заканчиваться пробелом.

выражение:
Код

SQL> select regexp_replace(upper(' '||'д тест ш тест вл'||' '), '\s(\Д|\Ш|\В\Л)\s', ' ') from dual
  2  /
 
REGEXP_REPLACE(UPPER(''||'ДТЕС
------------------------------
 ТЕСТ ТЕСТ


все ок, но:
Код

SQL> select regexp_replace(upper(' '||'д д тест ш ш тест вл вл'||' '), '\s(\Д|\Ш|\В\Л)\s', ' ') from dual
  2  /
 
REGEXP_REPLACE(UPPER(''||'ДДТЕ
------------------------------
 Д ТЕСТ Ш ТЕСТ ВЛ


в чем собственно проблема, где я натупил?
PM MAIL ICQ   Вверх
Zloxa
Дата 2.2.2012, 21:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Чо?
****


Профиль
Группа: Завсегдатай
Сообщений: 3473
Регистрация: 12.9.2008

Репутация: 37
Всего: 161



Цитата(DimW @  2.2.2012,  17:17 Найти цитируемый пост)
в чем собственно проблема

проблема в том что пробел перед вторым "д" был захвачен предыдущим матчем, просмотр продолжился начиная с "д", потому вторая "д" не захватилась.

идей, кроме задвоить пробелы в исходной строке, а потом обратно подтереться - нет.

Добавлено через 3 минуты и 20 секунд
Цитата(DimW @  2.2.2012,  17:17 Найти цитируемый пост)
\s(\Д|\Ш|\В\Л)\s

бэкслеши тут лишние. Означают буквально Do nothing
Код

\s(Д|Ш|ВЛ)\s



--------------------
Достоверно известно, что 89% людей доверяют статистике взятой с потолка smile
PM   Вверх
DimW
Дата 3.2.2012, 09:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1330
Регистрация: 24.2.2005
Где: Орёл

Репутация: 23
Всего: 44



Цитата(Zloxa @  2.2.2012,  21:31 Найти цитируемый пост)
проблема в том что пробел перед вторым "д" был захвачен предыдущим матчем, просмотр продолжился начиная с "д", потому вторая "д" не захватилась.


плакаль...  smile 


Цитата(Zloxa @  2.2.2012,  21:31 Найти цитируемый пост)
идей, кроме задвоить пробелы в исходной строке, а потом обратно подтереться - нет.

спасибо!
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

Данный раздел предназначен для обсуждения проблем с Oracle Database, другие продукты Oracle здесь не обсуждаются. Просьба при создании темы, придерживаться следующих правил:

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, LSD.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Oracle | Следующая тема »


 




[ Время генерации скрипта: 0.1054 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.