Регулярные выражения.pptx
- Количество слайдов: 42
Регулярные выражения
Введение • Стандартный класс string позволяет выполнять над строками различные операции, в том числе поиск, замену, вставку и удаление подстрок. Тем не менее, есть классы задач по обработке символьной информации, где стандартных возможностей явно не хватает. Чтобы облегчить решение подобных задач, в Net Framework встроен более мощный аппарат работы со строками, основанный на регулярных выражениях.
Введение • Регулярные выражения предназначены для обработки текстовой информации и обеспечивают: – Эффективный поиск в тексте по заданному шаблону; – Редактирование текста;
Введение • Регулярные выражения предоставляют мощный, гибкий и эффективный метод обработки текста. • Обширные возможности сопоставления шаблонов, предоставляемые регулярными выражениями, позволяют быстро анализировать большие объемы текста, отыскивая в них определенные символьные шаблоны, проверять текст на соответствие определенным заранее шаблонам (например, формату адреса электронной почты), извлекать, изменять, заменять или удалять подстроки текста, а также добавлять извлеченные строки в коллекцию для формирования отчетов.
Введение • Регулярные выражения — это незаменимый инструмент для многих приложений, в которых ведется работа со строками или анализ объемных блоков текста. • В регулярные выражения Microsoft. NET Framework включены наиболее распространенные методы, встречающиеся в других реализациях регулярных выражений, например в языках Perl и awk. Регулярные выражения. NET Framework совместимы с регулярными выражениями Perl 5.
Метасимволы в регулярных выражениях • Регулярное выражение – это шаблон, по которому выполняется поиск соответствующего фрагмента текста. • Язык описания регулярных выражений состоит из символов двух видов: обычных символов и метасимволов. • Обычный символ представляет в выражении сам себя, а метасимвол – некоторый класс символов.
Метасимволы Класс Описание символов Пример . Любой символ, кроме n. [] Любой одиночный символ из последовательности, записанной внутри скобок. Допускается использование диапазонов символов. Любой одиночный символ, не входящий в последовательность, записанную внутри скобок. Допускается использование диапазонов символов. Выражение c. t соответствует фрагментам: cat, cut, c#t, c{t и т. д. Выражение c[aui]t соответствует фрагментам: cat, cut, cit. Выражение c[a-c]t соответствует фрагментам: cat, cbt, cct. [^] Выражение c[^aui]t соответствует фрагментам: cbt, cct, c 2 t и т. д. Выражение c[^a-c]t соответствует фрагментам: cdt, cet, c%t и т. д.
Метасимволы w Любой алфавитно-цифровой Выражение cwt соответствует символ. фрагментам: cbt, cct, c 2 t и т. д. , но не соответствует фрагментам c%t, c{t и т. д. W Любой не алфавитно-цифровой Выражение cWt соответствует символ. фрагментам: c%t, c{t, c. t и т. д. , но не соответствует фрагментам cbt, cct, c 2 t и т. д. s Любой пробельный символ. S Любой не пробельный символ. Выражение sSSSs соответствует любым трем непробельным символам, окруженным пробельными. Выражение swwws соответствует любому слову из трех букв, окруженному пробельными символами.
Метасимволы d Любая десятичная цифра Выражение cdt соответствует фрагментам: c 1 t, c 2 t, c 3 t и т. д. D Любой символ, не Выражение cDt не соответствует являющийся десятичной фрагментам: c 1 t, c 2 t, c 3 t и т. д. цифрой Кроме метасимволов, обозначающие классы символов, могут применяться уточняющие метасимволы:
Уточняющие символы Уточняющие Описание символы ^ $ А Фрагмент, совпадающий с регулярными выражениями, следует искать только в начале строки Фрагмент, совпадающий с регулярными выражениями, следует искать только в конце строки Фрагмент, совпадающий с регулярными выражениями, следует искать только в начале многострочной строки
Уточняющие символы Z b B Фрагмент, совпадающий с регулярными выражениями, следует искать только в конце многострочной строки Фрагмент, совпадающий с регулярными выражениями, начинается или заканчивается на границе слова, т. е. между символами, соответствующими метасимволам w и W Фрагмент, совпадающий с регулярными выражениями, не должен встречаться на границе слов
Повторители • В регулярных выражениях часто используются повторители – метасимволы, которые располагаются непосредственно после обычного символа или группы символов и задают количество его повторений в выражении.
Повторители Описание Пример * Ноль или более Выражение ca*t соответствует повторений предыдущего фрагментам: элемента ct, caat, caaat и т. д. + Одно или более Выражение ca+t соответствует повторений предыдущего фрагментам: элемента cat, caaat и т. д. ? Не более одного Выражение ca? t соответствует повторения предыдущего фрагментам: элемента ct, cat.
Повторители {n} {n, m} Ровно n повторений Выражение ca{3}t соответствует предыдущего фрагменту: элемента cаааt. Выражение (cat){2} соответствует фрагменту: cаtcat. По крайней мере n Выражение ca{3, }t соответствует повторений фрагментам: cаааt, caaaaaaat предыдущего и т. д. элемента Выражение (cat){2, } соответствует фрагментам: cаtcat, catcatcat и т. д. От n до m повторений Выражение ca{2, 4}t соответствует предыдущего фрагментам: cааt, caaaat. элемента
Регулярное выражение • Регулярное выражение записывается в виде строкового литерала, причем перед строкой необходимо ставить символ @, который говорит о том, что строку нужно будет рассматривать и в том случае, если она будет занимать несколько строчек на экране. Однако символ @ можно не ставить, если в качестве шаблона используется шаблон без метасимволов.
Регулярное выражение • Если нужно найти какой-то символ, который является метасимволом, например, точку, можно это сделать защитив ее обратным слэшем. Т. е. просто точка означает любой одиночный символ, а . означает просто точку.
Примеры • Примеры регулярных выражений: – слово rus – @"rus" или "rus" – номер телефона в формате xxx-xx-xx – @"ddd-dd" или @"d{3}(-dd){2}" – номер автомобиля-@"[A-Z]d{3}[AZ]{2}d{2, 3}RUS"
Поиск в тексте по шаблону • Пространство имен библиотеки базовых классов System. Text. Regular. Expressions содержит все объекты платформы. NET Framework, имеющие отношение к регулярным выражениям. • Важнейшим классом, поддерживающим регулярные выражения, является класс Regex, который представляет неизменяемые откомпилированные регулярные выражения.
Поиск в тексте по шаблону • Для описания регулярного выражения в классе определено несколько перегруженных конструкторов: – Regex() – создает пустое выражение; – Regex(String) – создает заданное выражение; – Regex(String, Regex. Options) – создает заданное выражение и задает параметры для его обработки с помощью элементов перечисления Regex. Options (например, различать или нет прописные и строчные буквы).
Поиск в тексте по шаблону • Поиск фрагментов строки, соответствующих заданному выражению, выполняется с помощью методов Is. Mach, Matches класса Regex. • Метод Is. Mach возвращает true, если фрагмент, соответствующий выражению, в заданной строке найден, и false в противном случае. Например, попытаемся определить, встречается ли в заданном тексте слово собака:
Пример static void Main() { Regex r = new Regex("собака", Regex. Options. Ignore. Case); string text 1 = "Кот в доме, собака в конуре. "; string text 2 = "Котик в доме, собачка в конуре. "; Console. Write. Line(r. Is. Match(text 1)); Console. Write. Line(r. Is. Match(text 2)); }
Результат Regex. Options. Ignore. Case – означает, что регулярное выражение применяется без учеба регистра символов
Поиск в тексте по шаблону • Можно использовать конструкцию выбора из нескольких элементов. Варианты выбора перечисляются через вертикальную черту. Например, попытаемся определить, встречается ли в заданном тексте слов собака или кот:
Пример static void Main(string[] args) { Regex r = new Regex("собака|кот", Regex. Options. Ignore. Case); string text 1 = "Кот в доме, собака в конуре. "; string text 2 = "Котик в доме, собачка в конуре. "; Console. Write. Line(r. Is. Match(text 1)); Console. Write. Line(r. Is. Match(text 2)); }
Результат
Поиск в тексте по шаблону • Попытаемся определить, есть ли в заданных строках номера телефона в формате xx-xx-xx или xxx-xx-xx: static void Main() { Regex r = new Regex(@"d{2, 3}(-dd){2}"); string text 1 = "tel: 123 -45 -67"; string text 2 = "tel: no"; string text 3 = "tel: 12 -34 -56"; Console. Write. Line(r. Is. Match(text 1)); Console. Write. Line(r. Is. Match(text 2)); Console. Write. Line(r. Is. Match(text 3)); }
Результат
Метод Match • Метод Match класса Regex не просто определяет, содержится ли текст, соответствующий шаблону, а возвращает объект класса Match – последовательность фрагментов текста, совпавших с шаблоном. Следующий пример позволяет найти все номера телефонов в указанном фрагменте текста:
Результат
Следующий пример позволяет подсчитать сумму целых чисел, встречающихся в тексте: static void Main() { Regex r = new Regex(@"[-+]? d+"); string text = @"5*10=50 -80/40=-2"; Match teg = r. Match(text); int sum = 0; while (teg. Success) { Console. Write. Line(teg); sum += int. Parse(teg. To. String()); teg = teg. Next. Match(); } Console. Write. Line("sum=" + sum); }
Результат
Метод Matches • Метод Matches класса Regex возвращает объект класса Match. Collection – коллекцию всех фрагментов заданной строки, совпавших с шаблоном. • При этом метод Matches многократно запускает метод Match, каждый раз начиная поиск с того места, на котором закончился предыдущий поиск.
Результат
Редактирование текста • Регулярные выражения могут эффективно использоваться для редактирования текста. Например, метод Replace класса Regex позволяет выполнять замену одного фрагмента текста другим или удаление фрагментов текста:
Изменение номеров телефонов: static void Main(string[] args) { string text = @"Контакты в Москве tel: 123 -45 -67, 123 -34 -56; fax: 123 -56 -45. Контакты в Париже tel: 12 -34 -56; fax: 11 -56 -45"; Console. Write. Line("Старые данныеn"+text); string new. Text=Regex. Replace(text, "123 -", "890 -"); Console. Write. Line("Новые данныеn" + new. Text); }
Результат
Удаление всех номеров телефонов из текста: static void Main() { string text = @"Контакты в Москве tel: 123 -4567, 123 -34 -56; fax: 123 -56 -45. Контакты в Париже tel: 12 -34 -56; fax: 12 -56 -45"; Console. Write. Line("Старые данныеn"+text); string new. Text=Regex. Replace(text, @"d{2, 3}(dd){2}", ""); Console. Write. Line("Новые данныеn" + new. Text); }
Результат
Разбиение исходного текста на фрагменты: static void Main() { string text = @"Контакты в Москве tel: 12345 -67, 123 -34 -56; fax: 123 -56 -45. Контакты в Париже tel: 12 -34 -56; fax: 12 -56 -45"; string []new. Text=Regex. Split(text, "[ , . : ; ]+"); foreach( string a in new. Text) Console. Write. Line(a); }
Результат


