Проблема со спецсимволами с RegEx в C ++ - PullRequest
0 голосов
/ 07 сентября 2018

У меня проблема с заменой специальных символов в строке (из файлов журнала IIS Sharepoint), которые содержат доменное имя с косой чертой и имена, начинающиеся с t, n, r, что приводит к путанице с регулярными выражениями. мой код выглядит следующим образом:

std::setlocale(LC_ALL, ".ACP"); //Sets the locale to the ANSI code page obtained from the operating system. FR characters
std::string subject("2018-08-26 11:38:20 172.20.1.148 GET /BaseDocumentaire/Documents+de+la+page+Notes+de+services/Rappel+du+dispositif+de+Sécurité+relatif+aux+Moyens+de+paiement+et+d’épargne+en+agence.pdf - 80 0#.w|domainname\tonzaro 10.12.105.24 Mozilla/5.0+(Windows+NT+10.0;+Win64;+x64;+rv:61.0)+Gecko/20100101+Firefox/61.0 200 0 0 29984");
std::string result;
std::string g1, g2, g5, g9, g10; //str groups in regex

    try {
        std::regex re("(\\d{4}-\\d{2}-\\d{2})( \\d{2}:\\d{2}:\\d{2})( 172.20.1.148)( GET | POST | HEAD )((/.*){1,4}/.*.(pdf|aspx))( -.*)(domainname.[a-zA-Z0-9]*)( \\d+.\\d+.\\d+.\\d+)");
        std::sregex_iterator next(subject.begin(), subject.end(), re);
        std::sregex_iterator end;

        while (next != end) {
            std::smatch match = *next;
            std::cout << match.str() << "\n";
            std::cout << "-------------------------------------------" << "\n";
            g1 = match.str(1);
            g2 = match.str(2);
            g5 = match.str(5);
            g9 = match.str(9);
            g10 = match.str(10);
            next++;
        }

        std::cout << "Date: " + g1 << "\n";
        std::cout << "Time: " + g2 << "\n";
        std::replace(g5.begin(), g5.end(), '+', ' ');
        std::cout << "Link Document : " + g5 << "\n";
        std::cout << "User: " + g9 << "\n";
        std::cout << "IP: " + g10 << "\n";

    }
    catch (std::regex_error& e) {
        std::cout << "Syntax error in the regular expression" << "\n";
    }

Мой вывод для доменного имени: domainname onzaro

Любая помощь, пожалуйста, для этой проблемы с \, \ t, \ n или \ r?

Ответы [ 2 ]

0 голосов
/ 07 сентября 2018

Я бы настоятельно рекомендовал вам использовать необработанные строковые литералы . Это решение предназначено для случаев, когда литерал не должен обрабатываться каким-либо образом, например, ваш.

Синтаксис R "delimiter( raw_characters )delimiter", поэтому в вашем случае это может быть:

std::string subject(R"raw(2018-08-26 11:38:20 172.20.1.148 GET /BaseDocumentaire/Documents+de+la+page+Notes+de+services/Rappel+du+dispositif+de+Sécurité+relatif+aux+Moyens+de+paiement+et+d’épargne+en+agence.pdf - 80 0#.w|domainname\tonzaro 10.12.105.24 Mozilla/5.0+(Windows+NT+10.0;+Win64;+x64;+rv:61.0)+Gecko/20100101+Firefox/61.0 200 0 0 29984)raw");
std::regex re( R"raw((\d{4}-\d{2}-\d{2})( \d{2}:\d{2}:\d{2})( 172.20.1.148)( GET | POST | HEAD )((/.*){1,4}/.*.(pdf|aspx))( -.*)(domainname.[a-zA-Z0-9]*)( \d+.\d+.\d+.\d+))raw");

(возможно, я пропустил несколько лишних \ выше). Посмотри вживую.

Эти специальные символы, называемые escape-последовательностями, обрабатываются в строковых литералах на уровне компиляции (если быть точным, в phase 5 ). Для необработанных строковых литералов это преобразование подавляется.

Вам нет дела до обработки специальных символов. Вам просто нужно позаботиться о том, чтобы ")delimiter" не появлялось в вашем литерале, что, я думаю, может произойти в регулярном выражении.

0 голосов
/ 07 сентября 2018

'\t' - это один символ, горизонтальная табуляция. Если вам нужны символы \ и t, вам необходимо экранировать обратную косую черту: "\\t".

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...