|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
|
Сортировка по полю (разделение на три категории)24.11.2016, 00:36. Показов 1558. Ответов 25
Метки нет (Все метки)
Здравствуйте. Есть вопрос и есть БД с полями: username, comp и error. Последнее заполняется ошибками (логами), они делятся на три типа: предупреждения, ошибки и исключения, там есть свои ключевые слова, но при этом некоторые из них могут присутствовать как в исключениях так и в ошибках.
Так вот, как их (точнее поле error) можно разделить на три части? Реально ли вывести разделенное поле на тот же самый DBGrid или же StringGrid или же сами посоветуйте, пожалуйста?
0
|
|
| 24.11.2016, 00:36 | |
|
Ответы с готовыми решениями:
25
Сортировка структуры по полю Tag и по полю Eng Считывание данных из файла и разделение на категории (JSON) Разделение блока на три части |
|
W
115 / 115 / 33
Регистрация: 16.04.2013
Сообщений: 750
|
|||||||
| 24.11.2016, 09:21 | |||||||
1
|
|||||||
|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
|||||||||||||
| 24.11.2016, 13:18 [ТС] | |||||||||||||
![]() Вот реализации могут быть различные... Но логи не состоят только из слов ошибка, исключение и предупреждения а из строки типа: Warning: текст ошибки, дата ошибки, и ключевое END - означает, что ошибка была при завершении работы. Можно ли как-то пропарсить такую строку средствами Delphi или возможностями SQL - запросов? И можно вопрос по вашему запросу. На сколько я понял вторым параметром передается значение, а что передается третьим параметром?
На sql-tutorial прочитал про CHARINDEX, PATINDEX, SUBSTRING а еще LOCATE, REGEXP с ними возможно это реализовать?
0
|
|||||||||||||
|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
|||
| 24.11.2016, 14:39 [ТС] | |||
![]() Вот пример: Warning: текст предупреждения, дата, END - Сообщение-предупреждение записалось во время завершении работы, но это только примерно. Вот как его отнести к типу Warning и группе при завершении END, ну хотя бы к типу Warning, покажите, пожалуйста, хотя бы примерчик, чтобы суть словить
0
|
|||
|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
||
| 24.11.2016, 15:57 [ТС] | ||
|
Т.е нужно убрать все, что идет после даты и времени до двоеточия З.Ы. Можно отформатированное оставить в DGrid?
0
|
||
|
60 / 60 / 26
Регистрация: 30.05.2016
Сообщений: 293
|
||||||
| 24.11.2016, 16:24 | ||||||
|
FloppyDisc, можно менять то что выводится в грид, через DBGrid1DrawColumnCell
1
|
||||||
|
60 / 60 / 26
Регистрация: 30.05.2016
Сообщений: 293
|
|
| 24.11.2016, 16:27 | |
|
0
|
|
|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
||
| 24.11.2016, 16:31 [ТС] | ||
![]() Распишу так, есть поле LAST_ERR. В нем записи следующего характера: 1. Warning: while(isControllerDetected = false) sgThread Execute: 126 2. Error: param=переходы 3. 21.11.2016 16:05:30: BEGINWORKD 4. 21.11.2016 16:22:22: BEGINWORKD .... 5. 21.11.2016 16:37:38: ENDWORKD .... 6. 18.11.2016 16:15:30: SHOWMODAL END .... Вот такие вот записи, получается нужно оставить все, что идет после третьего (3) двоеточия после времени, т.е слова BEGINWORK, ENDWORK, SHOWMODAL END. Как вывести результаты в DBGrid отформатированным таким способом. Или лучше ориентироваться не на двоеточия, а уже на ключевые слова BEGINWORK, ENDWORK, SHOWMODAL END
0
|
||
| 24.11.2016, 16:35 | |
|
посмотрите функцию
https://msdn.microsoft.com/ru-... 86323.aspx
1
|
|
|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
|
| 24.11.2016, 16:35 [ТС] | |
|
rusqwe, проблема в том, что логи разные и я не могу ориентироваться на длину...
0
|
|
|
60 / 60 / 26
Регистрация: 30.05.2016
Сообщений: 293
|
|
| 24.11.2016, 16:37 | |
|
FloppyDisc, можно попробовать ориентироваться на вхождение каких то символов
0
|
|
|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
|
| 24.11.2016, 16:42 [ТС] | |
|
rusqwe, а можно на слова типа BEGINWORK или словосочетания SHOWMODAL END или же ориентироваться на определенное двоеточие, например третье?
0
|
|
|
60 / 60 / 26
Регистрация: 30.05.2016
Сообщений: 293
|
||||||
| 24.11.2016, 16:52 | ||||||
|
для BEGINWORK и SHOWMODAL END можно попробовать функцию pos()
Добавлено через 2 минуты а для двоеточие, пока в голову приходит цикл с перебором всей строки
0
|
||||||
|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
|||||||||||
| 24.11.2016, 18:11 [ТС] | |||||||||||
|
rusqwe,
Ну сделал так:
![]() Добавлено через 7 минут Ну и ваш же пример
0
|
|||||||||||
|
60 / 60 / 26
Регистрация: 30.05.2016
Сообщений: 293
|
|
| 24.11.2016, 21:10 | |
|
FloppyDisc, У Dbgrid есть событие DBGrid1DrawColumnCell, туда пишешь свой код, предварительно подправив. В примере выше вроде все понятно. С начало условие для column.Index='номер поля в гриде'. За место edita соответственно нужное поле из датасета. Сменить Showmessage , на DBGrid1.Canvas.TextOut(Rect.Left, Rect.Top, s); , где то что хотите видеть в гриде
1
|
|
| 24.11.2016, 21:10 | |
|
Помогаю со студенческими работами здесь
20
Фильтры сводной таблицы, категории товаров "Сумма по полю." Сделать разделение подвала на две, три части и заполнить их информацией Разделение текстового файла на три примерно одинаковой длины по границе строк Сортировка категории Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|