s
April 6, 2018, 3:38 a.m.

Обработка файла журнала и представление данных

C++, Qt

Здравствуйте, прошу подсказать статьи, что бы выполнить проект, суть которого заключается в том, что бы брать некоторые данные из файла (лога), к примеру, когда была открыта сессия пользователем и когда была закрыта для подсчёта времени его работы.

ejabberd.log-20180312
2

Do you like it? Share on social networks!

1
Evgenii Legotckoi
  • April 6, 2018, 1:26 p.m.
  • (edited)

Добрый день! Да как-то нет статей по парсингу логов.

По факту здесь нужно считывать файл построчно, проверять с чего начинается каждая строка и использовать для парсинга регулярные выражения.
Сам файл можно открыть так
QFile file("log.txt");
if (!file.open(QIODevice::ReadOnly | QIODevice::Text))
    return;

while (!file.atEnd()) {
    QByteArray line = file.readLine();
    process_line(line);
}
Чтобы получить QString из QByteArray, достаточно создать объект QString передав в его конструктор в качестве аргумента объект QByteArray.

Чтобы получить дату из строки
=INFO REPORT==== 2018-03-12 08:05:46 ===
Теоретически достаточно будет считать эту строку и воспользоваться статическим методом QDateTime::fromString() с указанием формата этой строки.
QDateTime timestamp = QDateTime::fromString(line, "=INFO REPORT==== yyyy-MM-dd hh:mm:ss ===");
Что касается второй строки, то там уже нужно будет заморачиваться с регулярными выражениями. Посмотрите в описание документации на QRegularExpression и QRegExp

    Comments

    Only authorized users can post comments.
    Please, Log in or Sign up
    • Last comments
    • AK
      April 1, 2025, 11:41 a.m.
      Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
    • Evgenii Legotckoi
      March 9, 2025, 9:02 p.m.
      К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
    • VP
      March 9, 2025, 4:14 p.m.
      Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
    • ИМ
      Nov. 22, 2024, 9:51 p.m.
      Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    • Evgenii Legotckoi
      Oct. 31, 2024, 11:37 p.m.
      Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup