Аватар для Kykysik12
3 / 3 / 0
Регистрация: 19.11.2013
Сообщений: 56

Разбить данные из ячейки на строки

14.12.2013, 20:24. Показов 1912. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго дня! Итак, вопрос:

Имеется таблица DBGrid, которая выводит данные из базы, лежащей на сервере. К примеру, данные такие:

Фильм1 Вт, Ср, Чт 18:00, 21:30
Фильм2 Пн, Сб 13:00, 15:30, 18:00
Фильм3 Чт 16:00, 20:30


При нажатии на определённую строку выводится окно, в нём DBGrid содержащий информацию ТОЛЬКО выделенной строки, например, при нажатии на вторую строку мы получим окно с таблицей:

Фильм2 Пн, Сб 13:00, 15:30, 18:00


Подскажите, пожалуйста, как сделать, чтобы при нажатии на строку данные выводились не так, как сейчас, а в формате:

Фильм2 Пн 13:00
Фильм2 Пн 15:30
Фильм2 Пн 18:00
Фильм2 Сб 13:00
Фильм2 Сб 15:30
Фильм2 Сб 18:00

Заранее спасибо!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.12.2013, 20:24
Ответы с готовыми решениями:

Разбить данные одной ячейки на несколько
Всем привет. Есть вопрос, на который надеюсь Вы мне поможете ответить. Имеется столбец ячеек с данными. Данные разделены внутри ячейки...

Как вытащить данные из ячейки и разбить их на части
Задача: на главной странице располагается блоки со следующими названиями: Керамическая плитка, Керамогранит и т.п.. При клике на которую...

Разбить текст ячейки (строки), содержащий разделитель, на строки макросом
Необходимо разбить текст в ячейке (с разделителями "Alt+Enter") на отдельные строки

8
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
14.12.2013, 22:27
Выводить не в dbgrid,а в stringgrid
0
 Аватар для Пытливый
3763 / 2271 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
14.12.2013, 22:36
Тут проблема в ином - необходимо содержание поля для второго и третьего столбца разобрать на составляющие.
Я думаю сначала надо прогнать содержание каждого из полей через пару TStringList получив набор строк из дней и времени, а вот уже потом можно это дело вывести хоть в StringGrid а хоть и в ListView - это уже не принципиально.
0
554 / 484 / 191
Регистрация: 11.12.2013
Сообщений: 2,507
14.12.2013, 23:25
может быть и разбить строку по разделителю. мне кажется целесообразнее прогонять строку не через TStringList, а написать функцию, которая формировала бы массив или прямо записывала строки в StringGrid.
0
 Аватар для Пытливый
3763 / 2271 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
15.12.2013, 00:43
Ну а зачем писать-то когда есть уже готовый класс который все это сделает? Вот скажем для примера:
Delphi
1
2
3
4
5
6
7
Var
 SL: TStringList;
begin
 SL := TStringList.Create;
 SL.Delimiter := ',';
 SL.DelimitedText := 'Вт, Ср, Чт';
...
и у нас будет список из 3-элементов, что и требовалось:
SL.Strings[0] = 'Вт';
SL.Strings[1] = 'Ср'
SL.Strings[2] = 'Чт'
2
 Аватар для SLideR11
5 / 4 / 1
Регистрация: 02.10.2013
Сообщений: 189
15.12.2013, 12:45
Цитата Сообщение от Пытливый Посмотреть сообщение
Вот скажем для примера:
Спасибо, очень полезно. Тоже столкнулся с подобной задачей. Скажите, а как узнать, сколько получилось строк в SL, чтобы правильно разбирать таблицу?

Добавлено через 4 часа 1 минуту
Модератор почему-то посчитал, что это не приемлемо выделять сообщение полностью... Переделаю сообщение.
Цитата Сообщение от Пытливый Посмотреть сообщение
Delphi
1
2
3
4
5
6
7
Var
*SL: TStringList;
begin
*SL := TStringList.Create;
*SL.Delimiter := ',';
*SL.DelimitedText := 'Вт, Ср, Чт';
...
Но вопрос всё же остался. Подскажите, как вычислить сколько строк получилось.
0
 Аватар для Пытливый
3763 / 2271 / 705
Регистрация: 29.05.2013
Сообщений: 9,622
15.12.2013, 12:55
Свойство SL.Count даст количество, только не забудьте что индексы элементов начинаются с 0 следовательно если в цикле, то пишем:
Delphi
1
2
for i := 0 to SL.Count - 1
do ...
2
 Аватар для Kykysik12
3 / 3 / 0
Регистрация: 19.11.2013
Сообщений: 56
15.12.2013, 12:58  [ТС]
Пытливый, Спасибо Вам огромное, очень выручили!
0
 Аватар для SLideR11
5 / 4 / 1
Регистрация: 02.10.2013
Сообщений: 189
15.12.2013, 12:58
Пытливый, и ещё раз, премного благодарен
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.12.2013, 12:58
Помогаю со студенческими работами здесь

Разбить текст ячейки (строки), содержащий разделитель, на строки
Необходимо разбить текст в ячейке (с разделителями "Alt+Enter") на отдельные строки

Разбить содержимое ячейки на строки
Всем привет! Есть такая задача: необходимо содержимое ячейки транспонировать в столбец. просто транспонировать не получается, тк надо в...

Как разбить объединённые разделителями данные при выгрузке в ячейки из объекта Dictionary?
В результате обработки данных кодом VBA, генерируются словари с результатами работы вычислений. Данные в каждом хранятся в виде: ...

Разбить данные на строки
Можете пожалуйста подсказать как вставить переносы в текст?? Есть файл с набором чисел, надо поставить перенос после каждого пятого числа....

Как автоматически скопировать данные одной ячейки первой строки в другую ячейку 2 строки
Здравствуйте!!! Дана таблица, или запрос Код |дата |Всего товара на складе |Приход товара от поставщика |Итого на складе...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

Новые блоги и статьи
Запрет удаления строк ТЧ документа при определенном условии
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
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru