Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/6: Рейтинг темы: голосов - 6, средняя оценка - 4.67
7 / 5 / 2
Регистрация: 23.06.2015
Сообщений: 57

Чем лучше распарсить вот такой лог

17.02.2022, 13:57. Показов 1539. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Code
1
44:57.046006-94004,SDBL,2,process=rphost,p:processName=db,OSThread=43152,t:clientID=2959,....
44:57.046006 - время
94004 - длительность
SDBL
2
process=rphost - далее произвольное количество таких пар

Какие лучше использовать библиотеки или инструменты?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
17.02.2022, 13:57
Ответы с готовыми решениями:

Как и чем лучше распарсить строку вида 54040.49.294-NACHALO
Есть строка 54040.49.294-NACHALO-3 54040.49.294-KONETS-2 Надо в отдельные переменные записать 54040.49.294 и NACHALO и 3 и...

Когда распаковывал файл с ним полезло Amigo и тд . Просканировал в ComboFix вот такой лог вышел
ComboFix 15-08-27.01 - Виталий 27.08.2015 16:03:11.1.4 - x64 Microsoft Windows 7 Домашняя базовая 6.1.7601.1.1251.7.1049.18.3950.2739 ...

Чем лучше вести лог приложения?
Через что лучше вести лог приложения? Надо для релизной версии писать в файл, можно заюзать встроенный QMessageLogger, может кто-то что-то...

8
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
17.02.2022, 14:07
Цитата Сообщение от leonidkorolev Посмотреть сообщение
Какие лучше использовать библиотеки или инструменты?
re.
0
7 / 5 / 2
Регистрация: 23.06.2015
Сообщений: 57
17.02.2022, 14:12  [ТС]
re это низкий уровень.
Может повыше есть ченить?
0
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
17.02.2022, 14:40
Цитата Сообщение от leonidkorolev Посмотреть сообщение
Может повыше есть ченить?
Kibana.
Кликните здесь для просмотра всего текста

0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
17.02.2022, 17:15
Цитата Сообщение от leonidkorolev Посмотреть сообщение
Какие лучше использовать библиотеки или инструменты
Те, которые написаны для парсинга логов именно этого приложения.

Добавлено через 4 минуты
P.S. Можно было не стесняться и сразу написать что это [censored] 1С...
1
148 / 111 / 37
Регистрация: 28.11.2013
Сообщений: 383
17.02.2022, 19:38
Python
1
2
3
4
5
6
7
8
9
10
11
12
text_data = '44:57.046006-94004,SDBL,2,process=rphost,p:processName=db,OSThread=43152,t:clientID=2959'
 
temp = text_data.split(',')
print(f"temp = {temp}")
 
time_data = temp[0].split('-')[0]
duration = temp[0].split('-')[1]
SD_data = temp[1]
number = temp[2]
process_data = temp[3]
 
print(process_data)


Непонятно, далее в строке у вас такие пары где-то повторяются? Нужно знать признак окончания пары.
0
7 / 5 / 2
Регистрация: 23.06.2015
Сообщений: 57
17.02.2022, 22:04  [ТС]
Arsegg, Kibana это визуализация насколько я понял, хотели сказать наверно elastiksearch? Я почитал про эластик. Тяжко заходит. Пока слабо представляю как прикрутить.

Добавлено через 7 минут
Цитата Сообщение от Garry Galler Посмотреть сообщение
Те, которые написаны для парсинга логов именно этого приложения.
Есть такие в природе? Подскажите.

Цитата Сообщение от Garry Galler Посмотреть сообщение
P.S. Можно было не стесняться и сразу написать что это [censored] 1С...
Это технологический журнал 1С. Чем эта информация поможет.
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
17.02.2022, 22:41
Цитата Сообщение от leonidkorolev Посмотреть сообщение
Чем эта информация поможет.
Тем, что кто-то мог бы вспомнить, про какой-нибудь Python парсер логов для 1С.
Я не вспомнил - возможно, что никто и не писал такого.

Цитата Сообщение от leonidkorolev Посмотреть сообщение
наверно elastiksearch?
Здесь понадобится полный стек ELK: elastic, logstash, kibana.
Парсинг логов и трансформацию в JSON документ, пригодный для поиска в эластике, делает logstash. Но среди сотни готовых паттернов логов именно для 1С, конечно, ничего нет. (думаю создатели logstash просто никогда не слышали про 1С: для syslog, apache, nginx, mysql все есть).
Так что писать фильтры (паттерны разбора) придется вручную.

типа такого...
Code
1
2
3
4
5
6
filter {
  grok {
    type => "some_access_log"
    patterns_dir => "/path/to/patterns/"
    pattern => "%{IP:client} %{WORD:method} %{URIPATHPARAM:request} %{NUMBER:bytes} %{NUMBER:duration}"
  }
Добавлено через 12 минут
Но ELK это все-таки тяжелая артиллерия для промышленного highload'а.
Поэтому если нужен просто разбор лога для построения простой таблички, стоит поднапрячься и написать кастомную регулярку на основе точного формата лога.

Добавлено через 9 минут
Но 1С-ники же сами уже написали себе инструмент. На 1С.
Чем не подходит?

Парсер технологического журнала 1С»
2
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
20.02.2022, 17:24
Цитата Сообщение от Skryp Посмотреть сообщение
temp = text_data.split(',')
Python
1
2
>>> text_data.split(',', 3)
['44:57.046006-94004', 'SDBL', '2', 'process=rphost,p:processName=db,OSThread=43152,t:clientID=2959']
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.02.2022, 17:24
Помогаю со студенческими работами здесь

Чем отличается? вот эти 2 строки и какую из них лучше использовать?
1 char * hello3 = "HELLO3"; 2 char hello4="HELLO4" ;

Написал вот такой код, ввода структуры. Первая структурная переменная вводится, а вторая нет. В чем дело?
#include <stdio.h> #include <conio.h> #include <string.h> #include <iostream> using namespace std; struct TRYC ...

Нужно нарисовать вот такой вот дом на языке программирования QBasic
Прошу очень Вашей помощи. Нужно нарисовать вот такой вот дом на языке программирования QBasic. В универе задали нарисовать дом в...

Вот такой вот error. Line too long (more than 1023 characters)
Отправляю запрос, а приходит BAD REQUEST answer := dk.PatchRequest('api/products/', j); В дебаггере посмотрел на длину...

Вот такой вот код, кто может посмотрите:
Смотрите в основном 3-ий кейз в нём необходимо взять текст из файла и его зашифровать по ксору наложением ключа, ключ сответственно сам...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru