Qt Использование многострочной опции QRegularExpression
Я пишу программу, которая использует QRegularExpression и MultilineOption, я написал этот код, но сопоставление останавливается на первой строке. Зачем? Где я делаю не так?
QString recv = "AUTH-<username>-<password>\nINFO-ID:45\nREG-<username>-<password>-<name>-<status>\nSEND-ID:195-DATE:12:30 2/02/2015 <esempio>\nUPDATEN-<newname>\nUPDATES-<newstatus>\n";
QRegularExpression exp = QRegularExpression("(SEND)-ID:(\\d{1,4})-DATE:(\\d{1,2}):(\\d) (\\d{1,2})\/(\\d)\/(\\d{2,4}) <(.+)>\\n|(AUTH)-<(.+)>-<(.+)>\\n|(INFO)-ID:(\\d{1,4})\\n|(REG)-<(.+)>-<(.+)>-<(.+)>-<(.+)>\\n|(UPDATEN)-<(.+)>\\n|(UPDATES)-<(.+)>\\n", QRegularExpression::MultilineOption);
qDebug() << exp.pattern();
QRegularExpressionMatch match = exp.match(recv);
qDebug() << match.lastCapturedIndex();
for (int i = 0; i <= match.lastCapturedIndex(); ++i) {
qDebug() << match.captured(i);
}
Кто-нибудь может мне помочь?
3 ответа
Ответ вы должны использовать .globalMatch
метод, а не .match
,
См. Документацию QRegularExpression по этому вопросу:
Пытается выполнить глобальное сопоставление регулярного выражения с заданной строкой предмета, начиная со смещения позиции внутри предмета, используя совпадение типа matchType и соблюдая заданные matchOptions. Возвращенный QRegularExpressionMatchIterator располагается перед первым результатом совпадения (если есть).
Также вы можете удалить QRegularExpression::MultilineOption
вариант, так как он не используется.
Образец кода:
QRegularExpressionMatchIterator i = exp.globalMatch(recv);
while (i.hasNext()) {
QRegularExpressionMatch match = i.next();
// ...
}
На самом деле у меня в Google был вопрос с похожей проблемой, но я не мог полностью согласиться с ответом, так как я думаю, что на большинство вопросов о многострочном сопоставлении с новым QRegularExpression можно ответить следующим образом:
используйте опцию QRegularExpression::DotMatchesEverythingOption, которая позволяет (.) сопоставлять символы новой строки. Что очень полезно, тогда портирование из QRegExp
Ты получил or
Выражение и первое верно, работа сделана. я думаю, вам нужно разделить строку и зациклить массив, чтобы сравнить с этим выражением.
Если данные каждый раз имеют одинаковую структуру, вы можете использовать что-то вроде этого:
"(AUTH)-<([^>]+?)>-<([^>]+?)>\\nINFO-ID:(\\d+)\\n(REG)-<([^>]+?)>-<([^>]+?)>-<([^>]+?)>-<([^>]+?)>\\n(SEND)-ID:(\\d+)-DATE:(\\d+):(\\d+) (\\d+)/(\\d+)/(\\d+) <([^>]+?)>\\n(UPDATEN)-<([^>]+?)>\\n(UPDATES)-<([^>]+?)>"
21 матчей