Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.88/34: Рейтинг темы: голосов - 34, средняя оценка - 4.88
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
MS SQL

Выгрузка в excel по запросу через delphi

26.10.2016, 10:22. Показов 7574. Ответов 42
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
здравствуйте
помогите плиз
создал базу много таблиц , заполняю её через delphi, хочу сделать кнопку выгрузки в шаблон excel.
но вот в чём интерес хочу выбирать какойто пункт , например город москва и всё что привязано к ней выгружалось например номера домов и улиц итд те чтобы можно было вытянуть всё по одному главному обьекту.
если есть програмка дайте посмотреть .
заранее благодарен
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.10.2016, 10:22
Ответы с готовыми решениями:

Выгрузка данных из Delphi в Excel
Делаю выгрузку данных через процедуру SendtoExcel. При заполнении массива пишу следующий код: Table1.DisableControls; Table1.First; ...

Выгрузка из Delphi в Excel, слетает кодировка
При выгрузке из Delphi в Excel, и много чего перепробывал, и менять кодировки и по другому писать, не получается. Подскажите. Код: ...

Delphi и Excel. Генерация номеров и выгрузка в txt
Добрый. Имею таблицу excel, которая содержит диапазон значений вида 000001-001000, следом идет строка 001001-002000 (всего...

42
57 / 57 / 10
Регистрация: 27.02.2010
Сообщений: 282
26.10.2016, 11:44
Выбери запросом все, что касается города и выведи в Эксель... Вопрос то в чем? Сделать за тебя программу или что-то не получается?
1
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
26.10.2016, 12:01  [ТС]
вообще не пойму как это сделать. хоть чтонибуть покажите
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
26.10.2016, 12:02
а с целью брался тогда?
0
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
26.10.2016, 12:03  [ТС]
хочу научится
0
 Аватар для pincet
1655 / 1154 / 173
Регистрация: 23.07.2010
Сообщений: 6,910
26.10.2016, 12:16
странный способ научиться. Тем более, при живом гугле
1
57 / 57 / 10
Регистрация: 27.02.2010
Сообщений: 282
26.10.2016, 15:22
Давайте по пунктам, что Вы сделали и где уперлись?
1
5980 / 4555 / 1095
Регистрация: 29.08.2013
Сообщений: 28,183
Записей в блоге: 3
27.10.2016, 09:13
может в раздел Delphi эту тему перенести?

там есть замечательная подсказка - Инструкция: Использование Excel из Delphi
1
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
27.10.2016, 09:35  [ТС]
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
begin
ExcelApp := CreateOleObject('Excel.Application');
ExcelApp.workbooks.open(ExtractFilePath(ParamStr(0 ))+'1.xlsx');
ExcelApp.Visible := true;
ExcelApp.WorkBooks[1].WorkSheets[1].name := '1';
sheet:=ExcelApp.WorkBooks[1].WorkSheets['1'];
index:=3;
 
for i:=1 to DBGrid2.DataSource.DataSet.RecordCount do
begin
for j:=1 to DBGrid2.FieldCount do
sheet.cells[index,7]:=DBGrid2.fields[2].asstring  ;
sheet.cells[index,15]:=DBGrid2.fields[9].asstring  +' ('+  DBGrid2.fields[10].asstring + ')';
sheet.cells[index,8]:=DBGrid24.fields[2].asstring    ;
sheet.cells[index,9]:=DBGrid24.fields[3].asstring    ;
sheet.cells[index,10]:=DBGrid24.fields[4].asstring    ;
sheet.cells[index,11]:=DBGrid24.fields[5].asstring    ;
inc(index);
DBGrid2.DataSource.DataSet.Next;
DBGrid24.DataSource.DataSet.Next;
end;
делал вот тким образом но мне только грид и выдаёт
мне необходимо допустим выбрать строку в гриде и все по ней вывести вместе с привязаными таблицами
как запрос впихивать непойму
0
5980 / 4555 / 1095
Регистрация: 29.08.2013
Сообщений: 28,183
Записей в блоге: 3
27.10.2016, 09:42
очередной раз

на форму Connection и Query
в Connection прописываете настройки для бд
далее

Delphi
1
2
3
4
5
6
7
8
  query.sql.text:='select Family, Name, Phone from Table where Family='+QuotedSTR(Edit1.Text);
  query.Open;
  while not query.eof do begin
     страница_эксель[X,Y]:=query.Fileds[0].Value;
     страница_эксель[X+1,Y]:=query.Fileds[1].Value;
     страница_эксель[X+2,Y]:=query.Fileds[2].Value;
     query.next;
  end;
как-то так
1
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
27.10.2016, 10:42  [ТС]
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
procedure TForm16.Button1Click(Sender: TObject);
var excelapp,sheet:variant ;
index: integer  ;
ADOQuery:TADOQuery;
 
begin
 
ExcelApp := CreateOleObject('Excel.Application');
ExcelApp.workbooks.open(ExtractFilePath(ParamStr(0 ))+'1.xlsx');
ExcelApp.Visible := true;
//ExcelApp.WorkBooks[1].WorkSheetS[1].name := '1';
//sheet:=ExcelApp.WorkBooks[1].WorkSheets['1'];
//index:=3;
        ADOQuery.SQL.Clear;
        ADOQuery.sql.text:='select id, holename from Ho where id='+  QuotedSTR(Edit1.Text);
        ADOQuery.Open;
        while not ADOQuery.eof do begin
        sheet.cells[7,7]:=ADOQuery.Fields[0].Value;
        ADOQuery.next;
        end;
//inc(index);
 
end;
вот сдесь пока на первых парах. дальше не пошел. ничего не появляется.
и появляется при нажатие на кнопку экспорта появляется ошибка
Миниатюры
Выгрузка в excel по запросу через delphi  
0
5980 / 4555 / 1095
Регистрация: 29.08.2013
Сообщений: 28,183
Записей в блоге: 3
27.10.2016, 10:45
вот это у вас в var ADOQuery:TADOQuery;
а где вы создаете Query? где привязываете его к Connection?

далее
вы в цикле перебираете результат
while not ADOQuery.eof do begin

и пишите его в ОДНУ ячейку, то есть если вы получите 100 строк - в ячейке будет только последняя
0
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
27.10.2016, 12:41  [ТС]
Delphi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
procedure TForm16.Button1Click(Sender: TObject);
var excelapp,sheet:variant ;
index: integer  ;
 
adoquery8:TADOQuery;
 
begin
 
ExcelApp := CreateOleObject('Excel.Application');
ExcelApp.workbooks.open(ExtractFilePath(ParamStr(0 ))+'1.xlsx');
ExcelApp.Visible := true;
ExcelApp.WorkBooks[1].WorkSheetS[1].name := '1';
sheet:=ExcelApp.WorkBooks[1].WorkSheets['1'];
index:=3;
  adoquery8.close;
  adoquery8.sql.clear;
  adoquery8.Connection:= ADOConnection1 ;
  adoquery8.sql.add('select id, lot from lot ');
  adoquery8.sql.text:='select id, lot from lot where id='+  QuotedSTR(Edit1.Text);
  adoquery8.Open;
 
        while not adoquery8.eof do begin
        sheet.cells[index,7]:=adoquery8.Fields[0].Value;
        sheet.cells[index,8]:=adoquery8.Fields[1].text;
        adoquery8.next;
        end;
inc(index);
 
 
end;
не получается выгружать. и выходит таже ошибка.
пробую пока на одной ячейки а не на интервале.
если беру компоненту существующюю ado то получается выгружать но меняется всё в клиентской программе.
0
5980 / 4555 / 1095
Регистрация: 29.08.2013
Сообщений: 28,183
Записей в блоге: 3
27.10.2016, 13:08
Цитата Сообщение от pek Посмотреть сообщение
не получается выгружать. и выходит таже ошибка.
потому что ты обращаешься к НЕ СОЗДАННОМУ adoquery8:TADOQuery;

Добавлено через 34 секунды
TADOQuery это не переменная, это объект. ее надо не просто объявить, но и создать
а после создания настроить
1
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
08.11.2016, 12:51  [ТС]
вот в этой строчке
Code
1
ExcelApp.WorkBooks[1].WorkSheets[1].name := '1';
почему то подчёркнуто красным
Code
1
WorkSheets[1].name
что это может быть?
0
5980 / 4555 / 1095
Регистрация: 29.08.2013
Сообщений: 28,183
Записей в блоге: 3
08.11.2016, 14:42
код то работает?
1
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
08.11.2016, 15:23  [ТС]
код то работает?
да работает
0
5980 / 4555 / 1095
Регистрация: 29.08.2013
Сообщений: 28,183
Записей в блоге: 3
09.11.2016, 11:49
то что подчеркивается создается и заполняется во время работы программы - сейчас там ничего нет
1
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
09.11.2016, 11:54  [ТС]
нифига не получается , не работает никакая выгрузка вообще. ранее вроде работало вот это простейшее пару ячеек в экскле выгружало. сейчас сразу ошибка
0
0 / 0 / 1
Регистрация: 27.04.2016
Сообщений: 376
09.11.2016, 11:56  [ТС]
вот ошибка сразу не прикрепилась
Миниатюры
Выгрузка в excel по запросу через delphi  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.11.2016, 11:56
Помогаю со студенческими работами здесь

Выгрузка в excel при переходе с Delphi 7 на Rad Studio XE3
Здравствуйте! Проблема с выгрузкой в excel при переходе с Delphi 7 на Rad Studio XE3. В частности нет вопросов к WorkBooks, но есть к...

При подключении к запросу через Excel не выводятся строки
В Access создал запрос: SELECT . & " " & . & " " & . AS name FROM WHERE Like '*.tiff' or Like '*.tiff' or Like '*.tiff' and ...

Выгрузка из Explorer в Excel через Access
Добрый день. Давно не работал с Access (лет этак 17, если быть точным). И вот на работе возникла необходимость с ним столкнуться(( Что-то...

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

Выгрузка отчета 1С за день (отчет по выручке) через excel vba
Добрый день. Есть тестовый макрос, выгрузки данных из 1С. Он работает. Не могу понять как мне выгрузить данные отчета??? В моем...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью в конфигурации КА2. Данные берутся из регистра сведений, по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru