{----------------------------------------------------------------------------- The contents of this file are subject to the Mozilla Public License Version 1.1 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.mozilla.org/MPL/MPL-1.1.html Software distributed under the License is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either expressed or implied. See the License for the specific language governing rights and limitations under the License. The Original Code is: JvgExport.PAS, released on 2003-01-15. The Initial Developer of the Original Code is Andrey V. Chudin, [chudin att yandex dott ru] Portions created by Andrey V. Chudin are Copyright (C) 2003 Andrey V. Chudin. All Rights Reserved. Contributor(s): Michael Beck [mbeck att bigfoot dott com]. Burov Dmitry, translation of russian text. You may retrieve the latest version of this file at the Project JEDI's JVCL home page, located at http://jvcl.sourceforge.net Known Issues: -----------------------------------------------------------------------------} // $Id: JvgExport.pas 10612 2006-05-19 19:04:09Z jfudickar $ unit JvgExport; {$I jvcl.inc} {$I windowsonly.inc} interface uses {$IFDEF USEJVCL} {$IFDEF UNITVERSIONING} JclUnitVersioning, {$ENDIF UNITVERSIONING} {$ENDIF USEJVCL} Windows, Messages, Graphics, ExtCtrls, SysUtils, Classes, Controls, Forms, DB, {$IFDEF JVCL_USEQuickReport} QuickRpt, QRExport, {$ENDIF JVCL_USEQuickReport} JvgTypes; type TOnExportProgress = procedure(Progress: Integer) of object; {$IFDEF JVCL_UseQuickReport} procedure ExportToExcel(QuickRep: TCustomQuickRep); {$ENDIF JVCL_UseQuickReport} procedure ExportDataSetToExcel(DataSet: TDataSet; OnExportProgress: TOnExportProgress); {$IFDEF USEJVCL} {$IFDEF UNITVERSIONING} const UnitVersioning: TUnitVersionInfo = ( RCSfile: '$URL: https://jvcl.svn.sourceforge.net/svnroot/jvcl/branches/JVCL3_36_PREPARATION/run/JvgExport.pas $'; Revision: '$Revision: 10612 $'; Date: '$Date: 2006-05-19 21:04:09 +0200 (ven., 19 mai 2006) $'; LogPath: 'JVCL\run' ); {$ENDIF UNITVERSIONING} {$ENDIF USEJVCL} implementation uses {$IFDEF USEJVCL} {$ENDIF USEJVCL} ComObj, JvgUtils; const cExcelApplication = 'Excel.Application'; cReport = 'Report'; {$IFDEF JVCL_UseQuickReport} procedure ExportToExcel(QuickRep: TCustomQuickRep); var P: PChar; XL: Variant; Sheet: Variant; I, J, RecNo: Integer; SL1, SL2: TStringList; AExportFilter: TQRCommaSeparatedFilter; MemStream: TMemoryStream; TempFileName: string; Buffer: array [0..MAX_PATH] of Char; function DeleteEOLs(const Str: string): string; var I: Integer; begin Result := Str; for I := 1 to Length(Result) do if Result[I] = #13 then Result[I] := ' '; end; begin try XL := GetActiveOleObject(cExcelApplication); except XL := CreateOleObject(cExcelApplication); end; GetTempPath(SizeOf(Buffer), Buffer); TempFileName := Buffer + 'JvgExportToExcelTemp.txt'; AExportFilter := TQRCommaSeparatedFilter.Create(TempFileName); try QuickRep.ExportToFilter(AExportFilter); finally AExportFilter.Free; end; XL.Visible := True; XL.WorkBooks.Add; XL.WorkBooks[XL.WorkBooks.Count].WorkSheets[1].Name := cReport; Sheet := XL.WorkBooks[XL.WorkBooks.Count].WorkSheets[cReport]; SL1 := TStringList.Create; SL2 := TStringList.Create; try // Sheet.SetBackgroundPicture(FileName:=ExtractFilePath(ParamStr(0))+'data\bg.JPG'); // Sheet.Cells[1, 1] := 'Biblio'; Sheet.Cells[1, 1].Font.Color := $FFFFFF; // Sheet.Cells[2, 1] := 'Globus'; Sheet.Cells[2, 1].Font.Color := $FFFFFF; // Sheet.Columns[1].ColumnWidth := 11; RecNo := 1; Sheet.Cells[RecNo, 1] := 'Report created on ' + DateToStr(Date); Sheet.Cells[RecNo, 1].Font.Italic := True; Inc(RecNo); Sheet.Cells[RecNo, 1] := 'User ' + UserName; Sheet.Cells[RecNo, 1].Font.Italic := True; Inc(RecNo, 2); Sheet.Cells[RecNo, 1] := ''; Sheet.Cells[RecNo, 1].Font.Bold := True; Sheet.Cells[RecNo, 1].Font.Size := 14; Inc(RecNo, 2); MemStream := TMemoryStream.Create; MemStream.LoadFromFile(TempFileName); P := MemStream.Memory; for I := 0 to MemStream.Size - 1 do if P[I] = Chr(0) then P[I] := ','; SL1.LoadFromStream(MemStream); MemStream.Free; for I := 0 to SL1.Count - 1 do begin SL2.CommaText := SL1[I]; for J := 0 to SL2.Count - 1 do Sheet.Cells[RecNo, 1 + J] := SL2[J]; Inc(RecNo); end; finally SL1.Free; SL2.Free; if FileExists(TempFileName) then DeleteFile(TempFileName); end; end; {$ENDIF JVCL_UseQuickReport} procedure ExportDataSetToExcel(DataSet: TDataSet; OnExportProgress: TOnExportProgress); var XL: Variant; Sheet: Variant; I, RecNo, ColIndex: Integer; begin try XL := GetActiveOleObject(cExcelApplication); except XL := CreateOleObject(cExcelApplication); end; XL.Visible := True; XL.WorkBooks.Add; XL.WorkBooks[XL.WorkBooks.Count].WorkSheets[1].Name := cReport; Sheet := XL.WorkBooks[XL.WorkBooks.Count].WorkSheets[cReport]; // Sheet.SetBackgroundPicture(FileName:=ExtractFilePath(ParamStr(0))+'bg.JPG'); // Sheet.Cells[1, 1] := 'Biblio'; Sheet.Cells[1, 1].Font.Bold := True; Sheet.Cells[1, 1].Font.Color := clWhite; // Sheet.Cells[2, 1] := 'Globus'; Sheet.Cells[2, 1].Font.Bold := True; Sheet.Cells[2, 1].Font.Color := clWhite; RecNo := 1; Sheet.Cells[RecNo, 2] := 'Document created on ' + DateToStr(Date) + ' ' + TimeToStr(Time); Sheet.Cells[RecNo, 2].Font.Italic := True; Inc(RecNo); Sheet.Cells[RecNo, 2] := 'User: ' + ComputerName + ' / ' + UserName; Sheet.Cells[RecNo, 2].Font.Italic := True; Inc(RecNo); Sheet.Cells[RecNo, 2] := 'Program: ' + ExtractFileName(ParamStr(0)); Sheet.Cells[RecNo, 2].Font.Italic := True; // Шапка { Header [translated] } Inc(RecNo, 3); ColIndex := 0; for I := 0 to DataSet.FieldCount - 1 do if DataSet.Fields[I].Visible then begin if DataSet.Fields[I].DisplayLabel <> '' then Sheet.Cells[RecNo, 2 + ColIndex] := DataSet.Fields[I].DisplayLabel else Sheet.Cells[RecNo, 2 + ColIndex] := DataSet.Fields[I].FieldName; Sheet.Cells[RecNo, 2 + ColIndex].Font.Bold := True; Sheet.Cells[RecNo, 2 + ColIndex].Font.Size := 10; Inc(ColIndex); end; // Данные пошли { Data has begun to pass in [translated] } DataSet.First; Inc(RecNo, 3); while not DataSet.Eof do begin ColIndex := 0; for I := 0 to DataSet.FieldCount - 1 do if DataSet.Fields[I].Visible then begin Sheet.Cells[RecNo, 2 + ColIndex] := DataSet.Fields[I].AsString; Inc(ColIndex); end; DataSet.Next; if Assigned(OnExportProgress) then OnExportProgress(Round((DataSet.RecNo * 100.0) / DataSet.RecordCount)); Inc(RecNo); end; end; {$IFDEF USEJVCL} {$IFDEF UNITVERSIONING} initialization RegisterUnitVersion(HInstance, UnitVersioning); finalization UnregisterUnitVersion(HInstance); {$ENDIF UNITVERSIONING} {$ENDIF USEJVCL} end.