Регулярные выражения, способ 3-й

28.04.18

Разработка - Запросы

На момент написания статьи на Инфостарте предлагали 2 способа проверки строки на соответствие шаблону. Первый с использованием внешних компонент, второй с использованием фабрики XDTO (голый парсинг текста не считаем). Предлагаю третий - с использованием языка запросов.

Откровенно говоря, этот способ работает дольше и предлагает меньшее богатство инструментов для создания шаблона, но тем не менее кому-то может показаться интересным, кроме того, не помешает знать о нем для общего развития. Пишем запрос:

|ВЫБРАТЬ
|    ВЫБОР
|        КОГДА &Строка ПОДОБНО &Шаблон
|            ТОГДА ИСТИНА
|        ИНАЧЕ ЛОЖЬ
|    КОНЕЦ КАК ЕстьСоответствие

Устанавливаем значения параметров и выполняем. В результате всегда будет 1 строка, содержащая в реквизите ЕстьСоответствие булево значение.

Для описания шаблона можно использовать следующие выражения:

  • %: любое количество произвольных символов 
  • _: один произвольный символ
  • []: любой одиночный символ из перечисленных внутри квадратных скобок.
  • [^]: любой одиночный символ, кроме тех, которые перечислены следом за значком отрицания
  • \: экранирование управляющих символов

Например:

  • "%АБВ%" - строка, в которой встречается последовательность "АБВ"
  • "%[А-Я1-5]%" - строка, в которой встречается любая киррилическая буква в верхнем регистре или цифра от 1 до 5
  • "%[АВБ]%" - строка, в которой встречается буква А, Б или В
  • "%[^К-Н]%" - строка, в которой не встречаются символы К, Л, М, Н.
  • "[0-3][0-9] ЯНВАР[ЬЯ] 20[0-9][0-9]" - дата в январе 21-го века )

Далее, можно писать множественные сравнения, собирать текст запроса из многих условий и вообще использовать как фантазия подскажет. Удачи!

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    184197    1024    403    

967

Обновление 1С Запросы Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 Абонемент ($m)

Данный инструмент помогает анализировать доработанную конфигурацию после обновления на новый релиз и находить «битые» тексты запросов, в которых участвуют несуществующие в новом релизе метаданные.

2 стартмани

06.02.2025    2174    17    XilDen    26    

36

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

В статье приведена удобная возможность отладки исполняемого запроса динамического списка.

03.12.2024    5681    artemusII    11    

23

Запросы Программист Бесплатно (free)

Увидел cheatsheet по SQL и захотелось нарисовать подобное, но про запросы.

18.10.2024    13090    sergey279    18    

65

Запросы Программист Платформа 1С v8.3 Запросы 1C:Бухгалтерия Бесплатно (free)

Столкнулся с интересной ситуацией, которую хотел бы разобрать, ввиду её неочевидности. Речь пойдёт про использование функции запроса АВТОНОМЕРЗАПИСИ() и проблемы, которые могут возникнуть.

11.10.2024    8180    XilDen    36    

90

СКД Механизмы типовых конфигураций Запросы Программист Платформа 1С v8.3 1С:Зарплата и кадры государственного учреждения 3 1С:Зарплата и Управление Персоналом 3.x Россия Бесплатно (free)

Работая с типовыми отчетами в конфигурациях «Зарплата и управление персоналом, редакция 3», «Зарплата и кадры государственного учреждения, редакция 3» и подобных, в схемах компоновки данных можно встретить конструкции запросов, которые обращаются к некоторым виртуальным таблицам.

20.08.2024    3164    PROSTO-1C    0    

23

Запросы Программист Запросы Бесплатно (free)

Отлаживая взаимодействие с базой данных, мы регулярно сталкиваемся с зависающими или подозрительно долго выполняющимися обращениями, негативно влияющими на производительность. О том, как в PostgreSQL выявить подозрительные запросы, основываясь на доступной о них информации, расскажем в статье.

16.08.2024    10765    user1840182    5    

29
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ImHunter 334 28.04.18 12:26 Сейчас в теме
Дык... В упр. формах - это только с переходом на сервер можно сделать. Да еще и будет обращение в БД.
Так-то да, запросное подобие по-проще регулярок. Но накладные расходы, мне кажется, будут слишком велики.
2. m-rv 978 28.04.18 13:06 Сейчас в теме
(1) ну понятно, что это не клиентский вариант )
на самом деле я использую этот вариант потому, что он (как не странно) дает выигрыш в производительности в специфических условиях: у меня множество строк (~1000) и множество шаблонов (~100) по которым их надо проверить. и запрос позволяет проверить такое "одним махом", другие варианты - только циклом.
3. ImHunter 334 28.04.18 13:12 Сейчас в теме
(2) Т.е., динамически генеришь огромный запрос? Хм... Тоже надо подумать в эту сторону.
Как раз занимаюсь разбором данных (экселей). Замаялся и уже в сторону НС начал думать;)
4. m-rv 978 28.04.18 13:16 Сейчас в теме
(3) да, именно так и именно при разборе экселя )))
5. Fragster 1154 28.04.18 14:26 Сейчас в теме
Но ведь это даже близко не регулярные выражения, которые все имеют ввиду https://ru.wikipedia.org/wiki/%D0%A0%D0%B5%D0%B3%D1%83%D0%BB%D1%8F%D1%80%D0%BD%D1­%8B%D0%B5_%D0%B2%D1%8B%D1%80%D0%B0%D0%B6%D0%B5%D0%BD%D0%B8%D­1%8F
tormozit; Aphanas; dmpas; +3 Ответить
7. m-rv 978 28.04.18 16:07 Сейчас в теме
(5) да, с манипуляциями беда, но у меня ощущение, что когда «все» говорят про регулярные выражения - имеют ввиду прежде всего поиск по шаблону, а с этим все ок
9. Fragster 1154 28.04.18 20:38 Сейчас в теме
(7) ну выделите с помощью выражений шаблона запроса 1с, например, число с разделителем из строки, эдакий аналог [1-9]\d*(((,|\.)\d{2})|(( )\d{3}))*
1.23, 1 000.00, 1 000 000.23 и т.п. (реально используемый пример для парсинга инвойсов из пдф)
10. m-rv 978 28.04.18 21:06 Сейчас в теме
(9) вы пытаетесь сказать, что инструментарий ненастолько богат, как, скажем в случае использования xdto?
11. Fragster 1154 03.05.18 10:18 Сейчас в теме
(10) Что-то типа того. Для себя решил что буду использовать для винды vbscript, в кроссплатформенном варианте - командную строку или свой http-сервис
8. palsergeich 28.04.18 19:58 Сейчас в теме
Штука конечно интересная, но на более менее большой таблице по производительности полный швах.
Единственное что быстро работает это конструкция ТЕКСТ% на строках ограниченной длинны попадающих в индекс по плану запроса, все остальное от лукавого.
Если такая задача становится - решать ее желательно другими методами.
Скажем так на жалких 100 000 позициях номенклатуры решение этой задачи через полнотекстовый поиск более чем на порядок быстрее, но там есть ньюансы.
А есть области где номенклатурные позиции измеряются миллионами (практически любое направление связанное с ремонтом, для каждой модели свой номенклатурный каталог)
Но если задача стоит в разборе таблицы, находящейся в памяти, как описано здесь в комментариях, то решение вполне себе приемлимо, но встает вопрос, а не проще напрямую через ADO подключится к екселю и выполнить запрос на его стороне, по своему опыту - 250 000 строк екселя запросом с отбрами и группировками выполнились за единицы секунд.
serverstar; +1 Ответить
15. serverstar 70 09.02.22 13:49 Сейчас в теме
12. jONES1979 03.05.18 11:59 Сейчас в теме
... И привести бы ещё ссылки на первые оба способа
13. starik-2005 3171 03.05.18 12:45 Сейчас в теме
(12) https://infostart.ru/public/464971/ - 2-й способ. Первый - это просто внешняя компонента от M$ (и других, кто умеет на C писать)..
14. МихаилМ 07.05.18 13:50 Сейчас в теме
в скд тоже есть оператор LIKE . и на сервер данные гонять не нужно. к тому же в вт не все типы колонок можно поместить, в в скд все.
более того : оператор like субд зависим .
16. user1393353 11 15.02.23 08:23 Сейчас в теме
Не работает, у меня например вот такое выражение "Менеджер-кассир+( [0-9]{1,2})?"
Оставьте свое сообщение