Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
48 / 87 / 11
Регистрация: 12.08.2013
Сообщений: 474

Тестер регулярок

16.07.2016, 23:52. Показов 1249. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите разобраться с тем, что нет так. Не работает следующее:
/\n/g не выделяет перевод на новую строку
/<b>/g не выделяет: "<b>"

а здесь соответствия перечисленного выше работают.

Весь код:
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<!doctype html>
<html lang="ru">
<head>
  <meta charset="utf-8">
  <title></title>
  <style>
    .firstRow td{ text-align: left; }
    #regex { width: 400px; }
    #flag {
      width: 50px;
      letter-spacing: 2px;
    }
    .fourthRow td div:first-child {
      border: 1px solid silver;
      width: 410px;
      position: relative;
    }
 
    #testString { resize: none; }
    #testString, #colorString {
      font-size: 16px;
      font-family: Verdana, sans-serif;
      padding:0;
      white-space: pre-wrap;
      word-wrap: break-word;
      width: 410px;
      border: none;
      outline: none;
    }
 
    #testString {
      z-index: 2;
      position:relative;
      background-color: transparent;
    }
 
    .fourthRow td div:first-child div {
      position: absolute;
      top: 1px;
      z-index: 1;
      color: transparent;
    }
    .m0 { background-color: #c4e3ff; }
    .m0_2 { background-color: #74c4ff; }
  </style>
</head>
<body>
 
  <table>
    <tr class="firstRow">
      <td>Регулярное выражение:</td>
      <td>Флаги:</td>
    </tr>
    <tr>
      <td>/ <input id="regex" type="text"> /</td>
      <td><input id="flag" type="text" placeholder="gmi"></td>
    </tr>
    <tr>
      <td colspan="2">Строка для тестирования:</td>
    </tr>
    <tr class="fourthRow">
      <td colspan="2">
        <div>
          <textarea id="testString" rows="12" maxlength="300"></textarea>
          <div id="colorString"></div>
        </div>
      </td>
    </tr>
  </table>
</body>
</html>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
  var regex = document.getElementById('regex');       // Регулярное выражение
  var flags = document.getElementById('flag');        // Флаг
  var str = document.getElementById('testString');    // Проверяемая строка
 
  regex.addEventListener("input", highlight, false);
  flags.addEventListener("input", highlight, false);
  str.addEventListener("input", highlight, false);
 
  // Подстветка соответсвия подстроки регулярному выражению
  function highlight() {
    var count = 0;   // Счётчик соответсвий
    var re = new RegExp(regex.value, flags.value);   // Создаём шаблон
    var s = str.value.replace(re, function () {
              var n = (++count % 2) ? '' : '_2';
 
              switch (arguments[0]) { // Угловые скобки заменить на мнемонику
                case "<": arguments[0] = "&lt;"; break;
                case ">": arguments[0] = "&gt;"; break;
              }
 
              return "<span class="m0" + n + "">" + arguments[0] + "</span>";
            });
    document.getElementById('colorString').innerHTML = s;
  }
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.07.2016, 23:52
Ответы с готовыми решениями:

Тестер регулярных выражений
Решил попробовать написать тестер регулярных выражений по типу как на этом сайте, только на порядок проще. Но проблема в том, что никак не...

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

Ограничение регулярок
Решил освоить регулярки, не могу найти внятного справочника. Поэтому просто изучаю примеры. Так вот, условие поиска ограничивается некими...

7
20 / 20 / 13
Регистрация: 22.11.2015
Сообщений: 109
17.07.2016, 04:42
Ошибка за ошибкой..
Пожалуйста, прежде, чем скидывать сюда код, протестируйте сначала в какой-нибудь песочнице.
http://codepen.io/basov/pen/vKpqKW?editors=1010

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
<html lang="ru">
<head>
  <meta charset="utf-8">
  <title></title>
  <style>
    .firstRow td{ text-align: left; }
    #regex { width: 400px; }
    #flag {
      width: 50px;
      letter-spacing: 2px;
    }
    .fourthRow td div:first-child {
      border: 1px solid silver;
      width: 410px;
      position: relative;
    }
 
    #testString { resize: none; }
    #testString, #colorString {
      font-size: 16px;
      font-family: Verdana, sans-serif;
      padding:0;
      white-space: pre-wrap;
      word-wrap: break-word;
      width: 410px;
      border: none;
      outline: none;
    }
 
    #testString {
      z-index: 2;
      position:relative;
      background-color: transparent;
    }
 
    .fourthRow td div:first-child div {
      position: absolute;
      top: 1px;
      z-index: 1;
      color: transparent;
    }
    .m0 { background-color: #c4e3ff; }
    .m0_2 { background-color: #74c4ff; }
  </style>
</head>
<body>
 
  <table>
    <tr class="firstRow">
      <td>Регулярное выражение:</td>
      <td>Флаги:</td>
    </tr>
    <tr>
      <td>/ <input id="regex" type="text"> /</td>
      <td><input id="flag" type="text" placeholder="gmi"></td>
    </tr>
    <tr>
      <td colspan="2">Строка для тестирования:</td>
    </tr>
    <tr class="fourthRow">
      <td colspan="2">
        <div>
          <textarea id="testString" rows="12" maxlength="300"></textarea>
            </div>
          <div id="colorString"></div>
        
      </td>
    </tr>
  </table>
</body>
</html>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
var regex = document.getElementById('regex');       // Регулярное выражение
  var flags = document.getElementById('flag');        // Флаг
  var str = document.getElementById('testString');    // Проверяемая строка
 
  regex.addEventListener("input", highlight, false);
  flags.addEventListener("input", highlight, false);
  str.addEventListener("input", highlight, false);
 
  // Подстветка соответсвия подстроки регулярному выражению
  function highlight() {
    var count = 0;   // Счётчик соответсвий
    var re = new RegExp(regex.value, flags.value);   // Создаём шаблон
    colorString.innerHTML = testString.value.replace(re, function () {
              var n = (++count % 2) ? '' : '_2';
 
              switch (arguments[0]) { // Угловые скобки заменить на мнемонику
                case "<": arguments[0] = "&lt;"; break;
                case ">": arguments[0] = "&gt;"; break;
              }
 
              return '<span style="color: blue" class="'+count+'' + n + '">' + arguments[0] + '</span>';
            });
  }
1
1137 / 685 / 412
Регистрация: 07.11.2015
Сообщений: 1,102
17.07.2016, 06:22
Там нужно еще преобразовывать "<" и ">" не только в совпавшем участке, но и в остальном тексте.
Как-то так:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
var regex = document.getElementById('regex'); // Регулярное выражение
var flags = document.getElementById('flag'); // Флаг
var str = document.getElementById('testString'); // Проверяемая строка
 
regex.addEventListener("input", highlight, false);
flags.addEventListener("input", highlight, false);
str.addEventListener("input", highlight, false);
 
// Подстветка соответсвия подстроки регулярному выражению
function highlight() {
   var txt = str.value; // Проверяемая строка
   var count = 0; // Счётчик соответсвий
   var re = new RegExp(regex.value, flags.value); // Создаём шаблон
   var result = '';
   var match = null;
   var last = 0;
   while (match = re.exec(txt)) {
      var n = (++count % 2) ? '' : '_2';
      var o = txt.substr(last, match.index - last);
 
      result += htmlEntities(o) + '<span class="m0' + n + '">' + htmlEntities(match[0]) + '</span>';
 
      last = match.index + match[0].length;
 
      if (!re.global) break;
      if (match.index == re.lastIndex) re.lastIndex++;
   }
 
   result += htmlEntities(txt.substr(last));
 
   document.getElementById('colorString').innerHTML = result;
}
 
function htmlEntities(s) {
   return s.replace(/[<>]/g, function(i) {
      return '&#' + i.charCodeAt(0) + ';';
   });
}
1
48 / 87 / 11
Регистрация: 12.08.2013
Сообщений: 474
17.07.2016, 06:34  [ТС]
Цитата Сообщение от Михаил_96 Посмотреть сообщение
Ошибка за ошибкой..
Пожалуйста, прежде, чем скидывать сюда код, протестируйте сначала в какой-нибудь песочнице.
Извиняюсь, моя ошибка, думал нормально всё скопировалось, а после вашего сообщения увидел, что код как-то криво скопировался из нотпада.

Emilien, большое спасибо, с угловыми скобками теперь нормально отрабатывает, а вот перевод строки так и не выделяется.
0
1137 / 685 / 412
Регистрация: 07.11.2015
Сообщений: 1,102
17.07.2016, 09:27
Лучший ответ Сообщение было отмечено Justff как решение

Решение

Цитата Сообщение от Justff Посмотреть сообщение
а вот перевод строки так и не выделяется.
А если добавить letter-spacing.
CSS
1
2
3
    #testString, #colorString {
      letter-spacing: 2px;
    }
1
48 / 87 / 11
Регистрация: 12.08.2013
Сообщений: 474
17.07.2016, 15:56  [ТС]
Спасибо, сам не додумался
0
48 / 87 / 11
Регистрация: 12.08.2013
Сообщений: 474
26.12.2016, 15:44  [ТС]
Emilien, не пойму одну вещь в вашем коде, почему-то обозначение границ слова c кириллицей не работает
JavaScript
1
\bcat\b
такой код выделяет cat
но если cat заменить на кот:
JavaScript
1
\bкот\b
выделение слова не работает
0
1137 / 685 / 412
Регистрация: 07.11.2015
Сообщений: 1,102
26.12.2016, 20:38
Частью слова считаются символы, входящие в состав символьного класса \w, который идентичен [a-zA-Z0-9_].
Т.е. кирилица сюда не входит.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.12.2016, 20:38
Помогаю со студенческими работами здесь

Объединение регулярок
Здравствуйте, как эти 2 регулярки можно объединить в одну? В 1 случае номера телефонов на ссылку меняются, во 2 случае электронная почта...

Объяснение регулярок
Объясните, пожалуйста, что каждый символ этих регулярок делает: $s = preg_match(&quot;~(?:(?:()\\w]+))$~ius&quot;,$arr,$m); $end...

Подскажите на счет регулярок
В общем пытаюсь разобраться, но что-то никак. Вот пример: Regex rgx = new Regex(&quot;&quot;); str = rgx.Replace(str, &quot;&quot;); Как...

Тонкости регулярок на lua
Есть строка: &quot;Мед1, Мед2 (а1, 2), Мед3, Мед4&quot; Нужно переписать либо такую регулярку: /+(\s\(*\))?/g Здесь проблема, что скобки...

Знатоки супа и регулярок подскажите
хочу распарсить в целях тренировки сайт с вакансиями, сразу импортирую нужные модулиfrom bs4 import BeautifulSoup import requests ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru