Componentes.Terceros.jvcl/official/3.32/run/JvgExport.pas

250 lines
7.2 KiB
ObjectPascal
Raw Blame History

{-----------------------------------------------------------------------------
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/tags/JVCL3_32/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;
// <20><><EFBFBD><EFBFBD><EFBFBD>
{ 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;
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>
{ 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.