首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > .NET > .NET >

求帮忙远道弄下delphi代码

2013-10-02 
求帮忙远程弄下delphi代码天啊,弄了一个晚上硬是没有弄好。就是将数据集的数据导入Excel。把A.mdb的数据(只

求帮忙远程弄下delphi代码
天啊,弄了一个晚上硬是没有弄好。
就是将数据集的数据导入Excel。把A.mdb的数据(只有一个表)快速的导入到1个Excel中~~
我在网上找了一个代码,做好了的,到我用它的时候一直报错。

引用
unit uExportXls;

interface

uses
  DB, Classes;

var
  CXlsBof: array[0..5] of Word = ($809, 8, 0, $10, 0, 0);
  CXlsEof: array[0..1] of Word = ($0A, 00);
  CXlsLabel: array[0..5] of Word = ($204, 0, 0, 0, 0, 0);
  CXlsNumber: array[0..4] of Word = ($203, 14, 0, 0, 0);
  CXlsRk: array[0..4] of Word = ($27E, 10, 0, 0, 0);
  CXlsBlank: array[0..4] of Word = ($201, 6, 0, 0, $17);

type
  TFldRec = record
    Title: string;
    Width: Integer;
  end;

  ExportXls = class(TObject)
  private
    FCol: word;
    FRow: word;
    FDataSet: TDataSet;
    Stream: TStream;
    FWillWriteHead: boolean;
    FBookMark: TBookmark;
    procedure IncColRow;
    procedure WriteBlankCell;
    procedure WriteFloatCell(const AValue: Double);
    procedure WriteIntegerCell(const AValue: Integer);
    procedure WriteStringCell(const AValue: string);
    procedure WritePrefix;
    procedure WriteSuffix;
    procedure WriteTitle;
    procedure WriteDataCell;

    procedure Save2Stream(aStream: TStream);
  public
    procedure Save2File(FileName: string; WillWriteHead: Boolean);
    constructor Create(aDataSet: TDataSet);
  end;
function ExportToXLS(const FileName: string; DataSet: TDataSet): Boolean;
implementation

uses SysUtils;

function ExportToXLS(const FileName: string; DataSet: TDataSet): Boolean;
begin
  Result := False;
  with ExportXls.Create(DataSet) do try
    Save2File(FileName, True);
    Result := True;
  finally
    Free;
  end;
end;

constructor ExportXls.Create(aDataSet: TDataSet);
begin
  inherited Create;
  FDataSet := aDataSet;
end;

procedure ExportXls.IncColRow;
begin
  if FCol = FDataSet.FieldCount - 1 then begin
    Inc(FRow);
    FCol := 0;
  end
  else
    Inc(FCol);
end;

procedure ExportXls.WriteBlankCell;
begin
  CXlsBlank[2] := FRow;
  CXlsBlank[3] := FCol;
  Stream.WriteBuffer(CXlsBlank, SizeOf(CXlsBlank));
  IncColRow;
end;

procedure ExportXls.WriteFloatCell(const AValue: Double);
begin
  CXlsNumber[2] := FRow;
  CXlsNumber[3] := FCol;
  Stream.WriteBuffer(CXlsNumber, SizeOf(CXlsNumber));
  Stream.WriteBuffer(AValue, 8);
  IncColRow;
end;

procedure ExportXls.WriteIntegerCell(const AValue: Integer);
var
  V: Integer;
begin
  CXlsRk[2] := FRow;
  CXlsRk[3] := FCol;
  Stream.WriteBuffer(CXlsRk, SizeOf(CXlsRk));
  V := (AValue shl 2) or 2;
  Stream.WriteBuffer(V, 4);
  IncColRow;
end;

procedure ExportXls.WriteStringCell(const AValue: string);
var
  L: Word;
begin
  L := Length(AValue);
  CXlsLabel[1] := 8 + L;
  CXlsLabel[2] := FRow;
  CXlsLabel[3] := FCol;
  CXlsLabel[5] := L;
  Stream.WriteBuffer(CXlsLabel, SizeOf(CXlsLabel));
  Stream.WriteBuffer(Pointer(AValue)^, L);
  IncColRow;
end;

procedure ExportXls.WritePrefix;
begin
  Stream.WriteBuffer(CXlsBof, SizeOf(CXlsBof));
end;

procedure ExportXls.WriteSuffix;
begin
  Stream.WriteBuffer(CXlsEof, SizeOf(CXlsEof));
end;

procedure ExportXls.WriteTitle;
var
  n: word;
begin
  for n := 0 to FDataSet.FieldCount - 1 do
    WriteStringCell(FDataSet.Fields[n].DisplayLabel); //显示标签名
end;

procedure ExportXls.WriteDataCell;
var
  Idx: word;
begin
  WritePrefix;
  if FWillWriteHead then WriteTitle;


  FDataSet.DisableControls;
  FBookMark := FDataSet.GetBookmark;
  FDataSet.First;
  while not FDataSet.Eof do begin
    for Idx := 0 to FDataSet.FieldCount - 1 do begin
      if FDataSet.Fields[Idx].IsNull then
        WriteBlankCell
      else begin
        case FDataSet.Fields[Idx].DataType of
          ftSmallint, ftInteger, ftWord, ftAutoInc, ftBytes:
            WriteIntegerCell(FDataSet.Fields[Idx].AsInteger);
          ftFloat, ftCurrency, ftBCD:
            WriteFloatCell(FDataSet.Fields[Idx].AsFloat);
          else
            if Assigned(FDataSet.Fields[Idx].OnGetText) then
              WriteStringCell(FDataSet.Fields[Idx].Text)
            else
              WriteStringCell(FDataSet.Fields[Idx].AsString);
        end;
      end;
    end;
    FDataSet.Next;
  end;
  WriteSuffix;
  if FDataSet.BookmarkValid(FBookMark) then FDataSet.GotoBookmark(FBookMark);
  FDataSet.EnableControls;
end;

procedure ExportXls.Save2Stream(aStream: TStream);
begin
  FCol := 0;
  FRow := 0;
  Stream := aStream;
  WriteDataCell;
end;

procedure ExportXls.Save2File(FileName: string; WillWriteHead: Boolean);
var
  aFileStream: TFileStream;
begin
  FWillWriteHead := WillWriteHead;
  if FileExists(FileName) then DeleteFile(FileName);
  aFileStream := TFileStream.Create(FileName, fmCreate);
  try
    Save2Stream(aFileStream);
  finally
    aFileStream.Free;
  end;
end;

end.



就是这个。  另外虽然我实现了批量导入EXCEL表格的内容到ACCESS中去,20多个。但我担心速度会慢,数据量有点大。所以如果有更好的办法最好了。    当然没有也就算了

目前最要紧的就是解决导出MDB中的数据到新的EXCEL文件中去。  在线等啊。。。大半夜的。  伤不起
明天要交~ delphi access 数据 excel
[解决办法]
其实如果用ADO引擎连接没那么复杂.试下Select into语法.
以前大富翁论坛上倒是有一篇讲用Select Into做各种数据库的转换的帖子.可惜大富翁不在了.
转换4W多条记录只需几秒钟。
核心语句:(只需二句)
1、XLS转MDB
.版本 2 .支持库 eDB 
数据库连接1.连接 (“Provider=Microsoft.Jet.OLEDB.4.0;Data Source=MDB数据库名;Persist Security Info=False”) 
数据库连接1.执行SQL (“SELECT * INTO 表名 FROM [Excel 8.0;DATABASE=XLS文件名].[XLS表名$] ”)
2、MDB转XLS 
.版本 2 .支持库 eDB 
数据库连接1.连接 (“Provider=Microsoft.Jet.OLEDB.4.0;Data Source=MDB数据库名;Persist Security Info=False”) 
数据库连接1.执行SQL (“SELECT * INTO [Excel 8.0;DATABASE=XLS文件名].[XLS表名] FROM 表名”)

热点排行