Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.12.25;
Скачать: CL | DM;

Вниз

QReports   Найти похожие ветки 

 
_xroot   (2005-11-07 11:37) [0]

Необходимо вывести на принт отчет в виде таблицы то есть:
1 колонка - Имена
2 колонка - Фамиилии
3 колонка - Прибыль
...
N колонка - ....

Но проблема в том, 4то изначально неизвестно какие будут колонки и их кол-во
Как с помощью QReport это релизовать


 
gvv   (2005-11-07 11:59) [1]

http://www.sources.ru/delphi/delphi_printing_content_dbgrid.shtml


 
mr.il ©   (2005-11-07 13:07) [2]

Создаешь  в excele шаблон.
Потом в коде пишешь типа:

var
 XL_2 : Variant;
 _Rov : Integer;
 _SW, _SS : Currency;
begin with DM_Zakaz do begin
 IBQ_ZakazData.DisableControls;
 IBQ_ZakazData.AutoCalcFields := False;

 XL_2 := CreateOleObject("Excel.Application");
 XL_2.Workbooks.Add(_Environment.Path_Rep+"ZakazBlank.XLT");

 XL_2.Range["A1"].Value := "Бланк-заказ № "+IntToStr(IBQ_Zakaz["ZAKAZ_ID"]);
 XL_2.Range["A4"].Value := "Дата составления: "+DateToStr(IBQ_Zakaz["Date_Doc"]);
 XL_2.Range["A5"].Value := "Поставщик: "+_NotNullStr(IBQ_ZakazZakazName.Value);
 IBQ_ZakazData.First; _Rov := 8; _SW := 0; _SS := 0;
 while not IBQ_ZakazData.Eof do begin
     XL_2.Range["B"+IntToStr(_Rov)].Value := _NotNullStr(IBQ_ZakazData["PROD_NAME"]);
     XL_2.Range["C"+IntToStr(_Rov)].Value := CurrToStr(IBQ_ZakazData["Quant_Z"]);
     XL_2.Range["D"+IntToStr(_Rov)].Value := _Quant2Bags(_NotNullCurr(IBQ_ZakazData["Quant_Z"]), _NotNullCurr(IBQ_ZakazData["CPB"]));
     XL_2.Range["E"+IntToStr(_Rov)].Value := _NotNullCurr(IBQ_ZakazData["Quant_Z"])*_NotNullCurr(IBQ_ZakazData["W"]);
     _SW := _SW+(_NotNullCurr(IBQ_ZakazData["Quant_Z"])*_NotNullCurr(IBQ_ZakazData["W"]));
     XL_2.Range["F"+IntToStr(_Rov)].Value := _NotNullCurr(IBQ_ZakazData["Quant_Z"])*_NotNullCurr(IBQ_ZakazData["Cost_Z"]);
     _SS := _SS+(_NotNullCurr(IBQ_ZakazData["Quant_Z"])*_NotNullCurr(IBQ_ZakazData["Cost_Z"]));
     Inc(_Rov);
   end;
   IBQ_ZakazData.Next;
 end;
 XL_2.Range["E"+IntToStr(_Rov)].Value := _SW;
 XL_2.Range["F"+IntToStr(_Rov)].Value := _SS;
 XL_2.Run("myAutoFill"); // это запуск макроса в шаблоне
 XL_2.Visible:=True;

 IBQ_ZakazData.AutoCalcFields := True;
 IBQ_ZakazData.EnableControls;
end; end;

и ни какого QReporta.

в D7  и выше в юсес надо вставить ComObj


 
mr.il ©   (2005-11-07 13:09) [3]

В плане колонок, там лего определять динамически, в какую писать.


 
Anatoly Podgoretsky ©   (2005-11-07 13:45) [4]

На моем сайте есть документация.



Страницы: 1 вся ветка

Текущий архив: 2005.12.25;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.028 c
3-1130234191
SupKlo
2005-10-25 13:56
2005.12.25
Как можно работать с базой Transbase? И где можно найти документа


2-1133101760
WebSQLNeeder
2005-11-27 17:29
2005.12.25
Максимальное количество строк в Memo


2-1133784476
Mothertrucker
2005-12-05 15:07
2005.12.25
Большоооой текст!


2-1134136713
fast2
2005-12-09 16:58
2005.12.25
Как вынуть из таблицы наименования полей?


2-1134256939
Antony17
2005-12-11 02:22
2005.12.25
Запуск стандартных процедур