|
Особый статус
623 / 221 / 164
Регистрация: 18.11.2015
Сообщений: 1,086
|
|
Сортировка по полю (разделение на три категории)24.11.2016, 00:36. Показов 1513. Ответов 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
Фильтры сводной таблицы, категории товаров "Сумма по полю." Сделать разделение подвала на две, три части и заполнить их информацией Разделение текстового файла на три примерно одинаковой длины по границе строк Сортировка категории Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования.
Часть библиотеки BedvitCOM
Использованы. . .
|
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога
SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
|