Russian Qt Forum
Мая 02, 2025, 04:01
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Пользовательский интерфейс (GUI)
>
QRegExp совпадение по OR или AND
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: QRegExp совпадение по OR или AND (Прочитано 2253 раз)
Astrologer
Гость
QRegExp совпадение по OR или AND
«
:
Октября 21, 2010, 14:36 »
Всем привет. Только начал знакомиться с RegExp и стоит следующая задача. Скажем есть следующие строки:
"SELECT * FROM baseTable where (
ALIAS = 'ddd' AND
)"
"SELECT * FROM baseTable where (
ALIAS = 'ddd' OR
)"
"SELECT * FROM baseTable where (
ALIAS is null
)"
"SELECT * FROM baseTable where (
base like '%one%' AND ALIAS is null
)"
Вопрос - как будет выглядеть RegExp чтобы найти AND или OR с конца строки не трогая поля? Заранее спасибо.
Что-то вроде - найти первое совпадение and или or c конца строки не далее символа ' или слова null. Как это будет выглядеть в регулярном выражении?
«
Последнее редактирование: Октября 21, 2010, 15:16 от Astrologer
»
Записан
shirushizo
Гость
Re: QRegExp совпадение по OR или AND
«
Ответ #1 :
Октября 21, 2010, 17:48 »
Найти первое совпадение and или or c конца строки вроде так "( AND | OR)$"
А чтобы до null и ' - есть костыль: QString::split(QRegexp("( null |')",Qt::CaseInsensitive)) и ищем только в последнем элементе полученого QStringList'а...
П.с: не тестил (враги сожгли диск с последним С++), в регулярных выражениях несилен. Подойдет как временный вариант (быдлокодером не называть и больно не бить).
Записан
trot
Гость
Re: QRegExp совпадение по OR или AND
«
Ответ #2 :
Октября 21, 2010, 18:58 »
(OR|AND)[\s]*(null[\s]*'?)?$
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...