Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
 Аватар для Landser
57 / 7 / 4
Регистрация: 18.04.2009
Сообщений: 429

Вывод параметрических запросов из dbgrid в excel

28.01.2010, 21:23. Показов 1366. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
доброго времени суток.
вот с чем столкнулся, вернее что не пойму как сделать:
при нажатии на кнопку в dbgrid появляется результат запроса, параметром для которого служит текст в edit1.text
я хочу, чтобы после каждого такого запроса строка из dbgrida добавлялась в exel таблицу, те каждый раз, как я нажимаю кнопку "добавить", строка пишется в exel,
такое я пытаюсь реализовать с помощью процедуры, предварительно создав
Delphi
1
Excel:=CreateOleObject('Excel.Application');
Delphi
1
2
3
4
5
6
7
8
while DBGrid1.DataSource.DataSet.Eof <> true do
 begin
   for i := 1 to DBGrid1.DataSource.DataSet.RecordCount do begin
   rec1[i] := DBGrid1.DataSource.DataSet.FieldByName('DATE').AsString;
    Sheet.Cells[1,i]:= rec1[i];
   DBGrideh1.DataSource.DataSet.Next;
   end;
 end;
а проблема то как раз в том, что я например выполнил 5 запросов, а в exel пишется результат последнего запроса, а вот как сделать, чтобы писались все?вроде кажется просто, а чё то сообразить не могу.подскажите пожалуйста!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
28.01.2010, 21:23
Ответы с готовыми решениями:

Выполнение параметрических запросов
доброго времени суток всем)) вот столкнулся с непонятной проблемой при выполнении параметрического запроса ADOQuery: имеются 2...

Вывод из DBGrid в Excel
procedure TForm1.SpeedButton1Click(Sender: TObject); var ExcelApp : variant; row :integer; col, index:integer; begin ...

Вывод из DBGrid в Excel
Добрый день, подскажите пожалуйста как сделать вывод из dbgrid в exсel корректным? У меня сейчас вообще выводится база данных в ексель, но...

2
1263 / 706 / 62
Регистрация: 21.12.2009
Сообщений: 2,256
29.01.2010, 06:12
У Вас в теле цикла
Delphi
1
Sheet.Cells[1,i]:= rec1[i];
Таким образом при отработке цикла вы всегда вставляете данные в одну и ту же строку приложения Excel с номером 1
Вам надо работать еще с одной переменной, допустим J и идентифицировать ее со строкой обработки данных.
Delphi
1
2
3
4
5
6
7
8
9
10
J := 1;
while DBGrid1.DataSource.DataSet.Eof <> true do
 begin
   for i := 1 to DBGrid1.DataSource.DataSet.RecordCount do begin
   rec1[i] := DBGrid1.DataSource.DataSet.FieldByName('DATE').AsString;
    Sheet.Cells[j,i]:= rec1[i];
   DBGrideh1.DataSource.DataSet.Next;
   end;
   inc(j);  
 end;
Я взял за основу Ваш код, хотя и не вполне понимаю зачем Вам
Delphi
1
rec1[i] := DBGrid1.DataSource.DataSet.FieldByName('DATE').AsString;
Без этого можно было обойтись, присваивая
Delphi
1
Sheet.Cells[j,i]:= DBGrid1.DataSource.DataSet.FieldByName('DATE').AsString;
Ну и фраза
а проблема то как раз в том, что я например выполнил 5 запросов
звучит как-то странно. Вы выполнили 5 запросов или получили в запросе 5 строк результата?
1
 Аватар для Landser
57 / 7 / 4
Регистрация: 18.04.2009
Сообщений: 429
29.01.2010, 20:54  [ТС]
SAMZ, спасибо за ответ
Я взял за основу Ваш код, хотя и не вполне понимаю зачем Вам
Delphi
1
rec1[i] := DBGrid1.DataSource.DataSet.FieldByName('DATE').AsString;
Без этого можно было обойтись, присваивая
Delphi
1
Sheet.Cells[j,i]:= DBGrid1.DataSource.DataSet.FieldByName('DATE').AsString;
rec1[i] используется ещё в программе, это глобальный массив
Цитата Сообщение от SAMZ
Ну и фраза
а проблема то как раз в том, что я например выполнил 5 запросов
звучит как-то странно. Вы выполнили 5 запросов или получили в запросе 5 строк результата?
я выполнил 5 запросов, вот и хочу, чтобы строки из дб грида одна за одной добавлялись в отчёт..
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.01.2010, 20:54
Помогаю со студенческими работами здесь

Вывод данных из dbGrid B Excel
Всем здравствуйте, помогите вывести таблицу в эксель, без новых компонентов. Таблица создается программно. Сам проект тут, таблица, которую...

Вывод информации из DBGrid в шаблон Excel
Добрый день! Перечитал кучу информации по заезженной теме, на всех сайтах и форумах, включая мой любимый cyberforum, смог сделать то, что...

Вывод DBGrid в виде таблицы Excel
Я понимаю что в форуме и в интернете этих тем куча,но я все равно не догоняю как его вывести На фотке есть БД и элементы которые я к ней...

DBGrid в Excel вывод отдельных записей
Вывожу из DBGrid в Excel и возникает проблема, я хочу выводить записи с 1-10 через строку с 11 по 14 и через строку 15 запись. Помогите! ...

Выборочный вывод строк из Excel через ADO в DBGrid
Здравствуйте. Необходимо обработать файл, выгруженный из 1С (во вложении). Т.е. убрав лишние строки вывести нужное. Делаю так: ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru