|
|
|
| Всем добрый день!
Помогите составить регулярное выражение. Даже два.
1) Есть строки, состоящие из одних цифр. Мне нужно найти в базе строки вида *AA*BB*, причем A должно отличаться от B. То-бишь, найти строки, где есть две пары цифр.
Я составил регулярное выражение '(\d)\1.*(\d)\2'.
При этом есть ньюанс:
матчинг его для выражения '544113' мне дает true, как и надо (есть две пары: '44' и '11')
При этом такой же результат и для другой строки: '544443', а меня это не устраивает, нужно, чтобы пары были разные (A<>B), а не одинаковые (A=B).
Пробовал матчить выражение '544113' с паттерном '(\d)\1.*([^\1])\2'. Выдает, что нет матча.
Помогите сделать нужный паттерн, плиз!
2. И еще один вопрос. Мне нужно еще одно регулярное выражение, которое выбирает те строки, у которых есть 3 одинаковых цифры подряд. Составил регулярное выражение '(\d)\1\1'. Но это выражение ищет мне и строки, где подряд 4 цифры или более. Как написать регулярное выражение, которое будет матчиться только для трех цифр рядом?
Подскажите, плиз, как это можно сделать? | |
|
|
|
|
|
|
|
для: Barvetal
(19.09.2011 в 17:24)
| | 1) хз если подойдёт
РВ: /((\d)\2)(?!\2)/
результат:
544113
544443
533332
или
РВ: /((\d)\2)(?!\1)/
результат:
544113
544443
533332
по такому же типу можно собрать и второе РВ, а можно и не собирать)) | |
|
|
|