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

Вниз

ОТЧЁТЫ !!! Скоро будут гореть   Найти похожие ветки 

 
ali_tash   (2005-02-26 22:15) [0]

Здравсвуйте
в скором времени мне придётся писать часть программы которая
отвечает за формирование отчётов.
так как отчётов более 100 ,то хотелось бы узнать как оптимальнее начать работу над этой задачей, чтоб на пол пути не пришлось всё переделовать.
Отчёты нужно выводить только в Word или Excel(не исползовать Rave и прочие) ,база InterBase

Подскажите какой нибуть генератор отчётов
либо ссылки по этой теме.
Буду благодарен за любую информацию


 
Fin ©   (2005-02-26 22:21) [1]

Я пользуюсь xlReport для Excel, быстро, удобно, мне нравиться.


 
vertal ©   (2005-02-26 22:46) [2]

> Отчёты нужно выводить только в Word или Excel
Если эти самые Word или Excel доступны, то можно их и использовать через OLE-автоматизацию. Гарантировано получение файла с правильным их родным форматом. Хотя по оптимальности это решение не котируется - ни по используемой памяти, ни по скорости.


 
GanibalLector ©   (2005-02-27 01:47) [3]

я использую позднее связывание(OLE).НравиЦа ;)
З.Ы. Некоторые советуют XML.Я пока не догнал,что это...Но понял,что это лучший вариант из всех существующий.


 
YurikGL ©   (2005-02-27 08:21) [4]


> Некоторые советуют XML.Я пока не догнал,что это..

http://www.microsoft.com/office/xml/default.mspx
http://www.microsoft.com/downloads/details.aspx?FamilyId=FE118952-3547-420A-A412-00A2662442D9&displaylang=en
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/dnexcl2k2/html/odc_xmlss.asp

Суть в том, что генерируешь файл *.xml а потом его открываешь вордом или екселем.

А еще http://www.delphimaster.ru/articles/dbtoword/index.html


 
Набережных С. ©   (2005-02-27 09:53) [5]


> YurikGL ©   (27.02.05 08:21) [4]
> http://www.delphimaster.ru/articles/dbtoword/index.html

"Во Word-e", между прочим, есть еще и функция проверки правописания, ага. Глаз режет. И к двум способам "добывать информацию об интерфейсе ворда" недурно было-бы упомянуть и третий, самый логичный - встроенная справка по VBA, но это уже дело вкуса.


 
Anatoly Podgoretsky ©   (2005-02-27 11:13) [6]

А на что они еще пригодны, это же не рукописи, если у тебя нет печки, то отдай в отдаленные районы, у них с теплом проблемы.


 
YurikGL ©   (2005-02-27 11:45) [7]


> Набережных С. ©   (27.02.05 09:53) [5]

Там еще косяки есть... исправить то, конечно, надо...


 
atruhin ©   (2005-02-27 11:56) [8]

xlReport - очень много возможностей. Я делал вариант хранения SQL запросов на свободной странице Excel, получается одна процедура выбора отчета (все они хранятся в заданной директории), и одна процедура загрузки любого отчета, все отчеты делаются непосредственно в Excel (т.е. создаешь SQL выражения для получения данных, xlReport автоматически помещает эти данные в нужные ячейки).


 
ali_tash   (2005-02-27 12:16) [9]

atruhin

можеш пример привести
и откуда можно скачать xlReport ?


 
Набережных С. ©   (2005-02-27 12:21) [10]


> YurikGL ©   (27.02.05 11:45) [7]

Ты меня тоже извини, погорячился:( Надо было письмом, а не сюда...Извини.


 
Fin ©   (2005-02-27 12:24) [11]


> ali_tash   (27.02.05 12:16) [9]

http://www.afalinasoft.com/


 
atruhin ©   (2005-02-27 12:52) [12]

Простой пример:

procedure TfrmDateReport.FindReport;
var
 sr: TSearchRec;
 FileAttrs: Integer;
 i : word;
begin
 FileAttrs := 0;
 if FindFirst("*.xls", FileAttrs, sr) = 0 then begin
    repeat
      for i:=1 to length(sr.Name) do
        if sr.Name[i]="." then break;
      if sr.Name[i]="." then dec(i);
      edReportName.Items.Add(Copy(sr.Name,1,i));
    until FindNext(sr) <> 0;
    FindClose(sr);
 end;
end;

procedure TfrmDateReport.xlRepBeforeBuild(Report: TxlReportG2);
var
 S : string;
 i : word;
 IWorksheet : IxlWorksheet;
begin
 with xlRep do begin
   IWorksheet := IWorkbook.Worksheets.Item["Лист2"] as IxlWorksheet;
   IWorksheet.Range["SQLDTBegin", EmptyParam].Value :=
 DateTime2SQL(DateOf(edDateBegin.Date)+TimeOf(edTimeBegin.Time));
   IWorksheet.Range["SQLDTEnd", EmptyParam].Value :=
 DateTime2SQL(DateOf(edDateEnd.Date)+TimeOf(edTimeEnd.Time));
   i:=1;
   repeat
     S := IWorksheet.Range["B"+inttostr(i), EmptyParam].Value;
     if S <> "" then begin
       try
  Form1.unSQLCon.ExecSQL(S);
except
  IWorksheet.Range["SQLError", EmptyParam].Value := "error in SQL - "+s;
  break;
end;
     end;
     inc(i);
   until S = "";
   tbLog.Close;
   tbLog.Open;
 end;
end;

А в листе Excel примерно так(простейший отчет):
create temp table reptbl (i1 varchar ,i2 float, i3 varchar)
insert into reptbl select compip, sum(summa), sum(trafic) from log where DATETIME>"SQLDTBegin" and DATETIME<"SQLDTEnd"  group by compip
но это сделано для SQLite где есть поддержка временных таблиц, для Firebird нужно немного поменять алгоритм, а вообще в XlReport более 100 страниц документации на русском языке.


 
YurikGL ©   (2005-02-27 13:44) [13]


> Набережных С. ©   (27.02.05 12:21) [10]

Если можно - скинь наиболее критичные вещи. Я давно собирался эту статью переписывать.

А по поводу справки VB, за все это время не использовал ее ни разу. Записи макроса, обычно, хватает...


 
YurikGL ©   (2005-02-27 13:44) [14]


> YurikGL ©   (27.02.05 13:44) [13]

YurikGL(#-#)newmail.ru


 
Набережных С. ©   (2005-02-27 15:00) [15]

Ну я ж говорю: справка - дело вкуса:) А критиковать по делу - это ж надо читать вдумчиво, а лень куда девать?:)


 
GanibalLector ©   (2005-02-27 16:28) [16]

2 YurikGL ©   (27.02.05 08:21) [4]
Я конечно все понимаю,но не на английском :(
З.Ы. И когда ж я заставлю себя его выучить?


 
YurikGL ©   (2005-02-27 20:21) [17]


> GanibalLector ©   (27.02.05 16:28) [16]

Сохраняешь из ворда нужный файл в формате xml, а потом смотришь из блокнота, например, как он внутри устроен.


 
Sergey_Masloff   (2005-02-27 22:19) [18]

vertal ©   (26.02.05 22:46) [2]
>Если эти самые Word или Excel доступны
...
>Хотя по оптимальности это решение не котируется - ни по >используемой памяти, ни по скорости.
Ну если данные в Excel вставлять обращаясь к Cells(x,y) то конечно... Если же работать ренджами засовывая заранее сформированные массивы - никаких проблем со скоростью. Принтер гораздо медленнее печатает.


 
Alex--   (2005-02-28 02:54) [19]

И в строну FastReport можно посмотреть. Быстрота создания, генерации отчетов. Возможность правки пользователем форм. Любая сложность, внутренний (паскале подобный) скрипт.
Экспорт в Excel(XML), Excel(OLE) и др. И не дорого.



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

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

Наверх




Память: 0.51 MB
Время: 0.057 c
1-1110791122
qwe
2005-03-14 12:05
2005.03.27
FindFirst


14-1109918703
leonidus
2005-03-04 09:45
2005.03.27
Ищу програмку менеджер документов Microsoft Office


1-1110800372
tex
2005-03-14 14:39
2005.03.27
Как заставить TImage сжать bmp-файл сохраняя пропорции


1-1110574325
andruxin
2005-03-11 23:52
2005.03.27
Вопрос по движку грамматики MS Word XP, нужно описание функций


14-1110139250
Серега
2005-03-06 23:00
2005.03.27
Подскажите компонент...