172 похожих чатов

В 14 postgres функция regexp_replace и regexp_match неверно обрабатывают комбинацию .*?

и .+?
нежадный алгоритм работает как жадный.
Проверил онлайн на 2х сайтах - выражение составил верное

10 ответов

7 просмотров

судя по примеру — это таки жадное выражение

Это вы решили маскировать данные в JSON через regexp'ы ? ;)

Ildar-Garaev Автор вопроса
Ildar Garaev
да :)

А это читали? Приведите пример куска JSON где есть ключ, значение которого надо скрыть (чувствительные данные замажьте), попробую помочь вам с regexp'ами если вы непременно их желаете.

Ildar Garaev
а где тут JSON

Не понял вопроса. Вы о том, что там речь о JSONB идет? Так всё это и для JSON применимо, за очень небольшим исключением.

Просто для информации: PostgreSQL использует собственный движок "регулярок", его поведение резко отличается от "привычных" (PCRE и т.п.) в нетривиальных случаях, поэтому: . Выражение Вы составили неверное (в PostgreSQL оно жадное, строго по документации). . Поэтому все "онлайн сайты" — мимо. . Какие на самом деле синтаксис и семантика "регулярок" в PostgreSQL — см. именно его документацию.

Ildar-Garaev Автор вопроса
Yaroslav Schekin
Просто для информации: PostgreSQL использует собст...

я нашел уже как надо. Если жадное первое выражение до оно автоматом делает всех жадными на этом уровне. Я переписал и все получилось. Но это конечно не однозначное поведение

Ildar Garaev
я нашел уже как надо. Если жадное первое выражение...

Да поведение-то совершенно однозначное и логичное, как раз... но есть один нюанс: "The main problem with pg's regex engine is how it handles non-greedy constructs — it has a rule for how they should work which is simple and consistent and which always does nothing like what you actually want." © RhodiumToad

Похожие вопросы

Обсуждают сегодня

Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
2
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
у меня программа тысяч на 10 строк. Там в основном моя собственная логика. А по содержанию она просто работает с файловой системой (мастер для бэкапов) и таблицей с данными о ...
Дмитрий Завгородний
5
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Карта сайта