Простая в использовании поддержка регулярных выражений в C++?

Я ищу надежный, простой в использовании оценщик регулярных выражений для нативного C++, независимо от платформы или специфичного для Windows.

Требования:

  • Не могу использовать библиотеки регулярных выражений Boost или ACE (к сожалению)
  • Невозможно использовать .NET Regex (или любой управляемый код)

Главное требование - он должен быть автономным и открытым.

Просто любопытно - почему нельзя использовать буст?

svec 06.08.2008 20:16

@svec Поскольку исходный код предназначен для распространения, и многие из тех, кто его использует, не имеют Boost и не могут или не хотят загружать и создавать Boost. Но некоторые библиотеки планируется включить, так что это хорошо. Должно было случиться 5 лет назад, но привет. Во всех смыслах.

user2189331 11.08.2008 10:10

Но у клиентов не обязательно должен быть установлен Boost. Просто свяжите статически с бустом, и проблем быть не должно. (И в любом случае вы всегда должны связывать статически с boost, поскольку даже если клиенты установили его, у них может быть не та же версия или они скомпилировали ее с одинаковыми параметрами.)

James Kanze 07.08.2013 22:17

@JamesKanze - это зависимость от исходного кода, поскольку мы распространяем исходники, а не встроенную библиотеку. Если бы это было на мое усмотрение, все основные компиляторы C++ и IDE поставлялись бы с Boost. Когда в 2008 году был задан этот вопрос, это было далеко не так. Достаточно сложно заставить людей использовать STL, не говоря уже о Boost.

user2189331 08.05.2014 22:49

@JamesDevlin Я не знаю о доставке с Boost; Boost - не панацея, и я решаю, использовать ли его в каждом конкретном случае. (Фактически, поскольку теперь я могу использовать C++ 11, я вообще не использую Boost. Раньше я использовал его только для регулярных выражений.)

James Kanze 09.05.2014 12:16
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
29
5
2 318
10
Перейти к ответу Данный вопрос помечен как решенный

Ответы 10

попробуйте libpcre

Если вы застряли в окнах, у них есть порт Windows, который должен работать. Я знаю, что редактор электронных сообщений использует его, так что, по крайней мере, это доказательство того, что он работает :-)

Библиотека GNU C поддерживает обычные выражения. Он открыт, и код RE кажется легко извлекаемым.

Средство регулярных выражений библиотеки GNU C (regcomp (), regexec () и другие) не работает. Вместо этого используйте libetre; сигнатуры функций соответствуют сигнатурам, предоставленным glibc. http://laurikari.net/tre/

Если вы используете Visual Studio, вы можете использовать Visual C++ 2008 Feature Pack Release, он реализует часть TR1 и включает синтаксический анализ регулярных выражений. Возьми

Qt также имеет хорошую реализацию Регулярное выражениеQRegExp. Он также не зависит от платформы.

Почему бы вам не использовать библиотеку регулярных выражений Microsoft ATL? Кенни Керр недавно написал по этому поводу короткая статья.

ATL includes a lightweight regular expression implementation. Although originally part of Visual C++, it is now included with the ATL Server download.

The CAtlRegExp class template implements the parser and matching engine. ...

The regular expression grammar is defined at the top of the atlrx.h header file.

Я бы поддержал рекомендацию по PCRE. Я использовал его в проектах C++ в Windows, и он отлично работает. Это бесплатно даже для создания коммерческого программного обеспечения. Он также реализует что-то вроде стандартного языка регулярных выражений де-факто, который будет приветствоваться вашими пользователями. PCRE, конечно, совместим с Perl, и Python также использует ту же библиотеку.

Собственный интерфейс PCRE немного неудобен и очень похож на язык C, поэтому, вероятно, стоит написать для него хорошую оболочку C++. Скорее всего, он уже есть, но я с ним не знаком.

Бесплатная серверная библиотека ATL и инструменты от CodePlex включают парсер регулярных выражений. См. AtlServer в архиве CodePlex

ATL Server is a library of C++ classes that allow developers to build both client and server parts of service-type C++ applications and web services. It provides much of the functionality required to build large scale internet sites, such as SOAP messaging, caching facilities, threading facilities, regular expression processing, management of session-state, performance monitoring, MIME support, integration with IIS and class for interacting with security and cryptographic infrastructure. The earlier versions of the library are parts of Visual Studio 2002, Visual Studio 2003 and Visual Studio 2005. The project has started from the version of the library released as part of Visual Studio 2005 SP1.

Ответ принят как подходящий

C++ 11 теперь включает поддержку регулярных выражений. Он не будет зависеть от платформы. Вам просто нужен последний компилятор. Проверьте следующий список, чтобы узнать, какой из них использовать.

http://wiki.apache.org/stdcxx/C%2B%2B0xCompilerSupport

Надеюсь, это поможет

Ссылка wiki.apache.org/stdcxx/C%2B%2B0xCompilerSupport ведет на страницу «Страница не найдена».

Yaroslav Voytovych 08.01.2021 18:57

C++ 11 и более поздние версии теперь содержат стандартная библиотека регулярных выражений.
Включите заголовок <regex> и пользуйтесь.

Другие вопросы по теме

Как игнорировать определенный префикс в начале, если он выходит, и сопоставить остальные
Регулярное выражение для повторяющихся последовательностей символов
Регулярное выражение ReactJS не работает с разделенной строкой
PowerShell Regex: удаление определенных частей строки на основе шаблонов
Удаление всех слов, кроме первой буквы, с помощью регулярного выражения в LibreOffice Writer
Почему некоторые функции регулярных выражений возвращают объект соответствия, а некоторые нет?
Регулярное выражение для проверки того, содержит ли ввод две заданные строки, а часть между ними не содержит ни одного элемента из набора указанных строк
Regex: сопоставить кратчайший шаблон между двумя возможными разделителями
Использованиеdependent_wider_regex для создания новой строки для каждого совпадения в R
Добавить новые строки перед выбранными символами дефиса