摘自:http://wenjieshiyu.blog.163.com/blog/static/10739413201072033115869/數據庫
我的收藏:
Delphi 控制Excel
(一) 使用動態建立的方法
首先建立 Excel
對象,使用ComObj:
var ExcelApp: Variant;
ExcelApp := CreateOleObject(
'Excel.Application' );
1) 顯示當前窗口:
ExcelApp.Visible := True;
2) 更改 Excel
標題欄:
ExcelApp.Caption := '應用程序調用 Microsoft Excel';
3)
添加新工做簿:
ExcelApp.WorkBooks.Add;
4) 打開已存在的工做簿:
ExcelApp.WorkBooks.Open(
'C:\Excel\Demo.xls' );
5)
設置第2個工做表爲活動工做表:
ExcelApp.WorkSheets[2].Activate; 或 ExcelApp.WorksSheets[
'Sheet2' ].Activate;
6) 給單元格賦值:
ExcelApp.Cells[1,4].Value :=
'第一行第四列';
7)
設置指定列的寬度(單位:字符個數),以第一列爲例:
ExcelApp.ActiveSheet.Columns[1].ColumnsWidth :=
5;
8)
設置指定行的高度(單位:磅)(1磅=0.035釐米),以第二行爲例:
ExcelApp.ActiveSheet.Rows[2].RowHeight :=
1/0.035; // 1釐米
9) 在第8行以前插入分頁符:
ExcelApp.WorkSheets[1].Rows.PageBreak :=
1;
10) 在第8列以前刪除分頁符:ExcelApp.ActiveSheet.Columns[4].PageBreak := 0;
11)
指定邊框線寬度:
ExcelApp.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight :=
3;
1-左 2-右 3-頂 4-底 5-斜( \ ) 6-斜( / )
12)
清除第一行第四列單元格公式:
ExcelApp.ActiveSheet.Cells[1,4].ClearContents;
13)
設置第一行字體屬性:ExcelApp.ActiveSheet.Rows[1].Font.Name :=
'隸書';
ExcelApp.ActiveSheet.Rows[1].Font.Color :=
clBlue;
ExcelApp.ActiveSheet.Rows[1].Font.Bold :=
True;
ExcelApp.ActiveSheet.Rows[1].Font.UnderLine := True;
14)
進行頁面設置:
a.頁眉:
ExcelApp.ActiveSheet.PageSetup.CenterHeader :=
'報表演示';
b.頁腳:
ExcelApp.ActiveSheet.PageSetup.CenterFooter :=
'第&P頁';
c.頁眉到頂端邊距2cm:
ExcelApp.ActiveSheet.PageSetup.HeaderMargin
:= 2/0.035;
d.頁腳到底端邊距3cm:
ExcelApp.ActiveSheet.PageSetup.HeaderMargin
:= 3/0.035;
e.頂邊距2cm:
ExcelApp.ActiveSheet.PageSetup.TopMargin :=
2/0.035;
f.底邊距2cm:
ExcelApp.ActiveSheet.PageSetup.BottomMargin :=
2/0.035;
g.左邊距2cm:
ExcelApp.ActiveSheet.PageSetup.LeftMargin :=
2/0.035;
h.右邊距2cm:
ExcelApp.ActiveSheet.PageSetup.RightMargin :=
2/0.035;
i.頁面水平居中:
ExcelApp.ActiveSheet.PageSetup.CenterHorizontally :=
2/0.035;
j.頁面垂直居中:
ExcelApp.ActiveSheet.PageSetup.CenterVertically :=
2/0.035;
k.打印單元格網線:
ExcelApp.ActiveSheet.PageSetup.PrintGridLines :=
True;
15) 拷貝操做:
a.拷貝整個工做表:
ExcelApp.ActiveSheet.Used.Range.Copy;
b.拷貝指定區域: ExcelApp.ActiveSheet.Range[
'A1:E2' ].Copy;
c.從A1位置開始粘貼: ExcelApp.ActiveSheet.Range.[ 'A1'
].PasteSpecial;
d.從文件尾部開始粘貼:
ExcelApp.ActiveSheet.Range.PasteSpecial;
16) 插入一行或一列:
a.
ExcelApp.ActiveSheet.Rows[2].Insert;
b.
ExcelApp.ActiveSheet.Columns[1].Insert;
17) 刪除一行或一列:
a.
ExcelApp.ActiveSheet.Rows[2].Delete;
b.
ExcelApp.ActiveSheet.Columns[1].Delete;
18)
打印預覽工做表:
ExcelApp.ActiveSheet.PrintPreview;
19)
打印輸出工做表:
ExcelApp.ActiveSheet.PrintOut;
20) 工做表保存:
if not
ExcelApp.ActiveWorkBook.Saved then
ExcelApp.ActiveSheet.PrintPreview;
21) 工做表另存爲:
ExcelApp.SaveAs(
'C:\Excel\Demo1.xls' );
22) 放棄存盤:
ExcelApp.ActiveWorkBook.Saved :=
True;
23) 關閉工做簿:
ExcelApp.WorkBooks.Close;
24) 退出
Excel:
ExcelApp.Quit;
(二) 使用Delphi 控件方法
在Form中分別放入ExcelApplication,
ExcelWorkbook和ExcelWorksheet。
1) 打開Excel
ExcelApplication1.Connect;
2)
顯示當前窗口:
ExcelApplication1.Visible[0]:=True;
3) 更改 Excel
標題欄:
ExcelApplication1.Caption := '應用程序調用 Microsoft Excel';
4)
添加新工做簿:
ExcelWorkbook1.ConnectTo(ExcelApplication1.Workbooks.Add(EmptyParam,0));
5)
添加新工做表:
var Temp_Worksheet:
_WorkSheet;
begin
Temp_Worksheet:=ExcelWorkbook1.
WorkSheets.Add(EmptyParam,EmptyParam,EmptyParam,EmptyParam,0)
as _WorkSheet;
ExcelWorkSheet1.ConnectTo(Temp_WorkSheet);End;
6)
打開已存在的工做簿:
ExcelApplication1.Workbooks.Open
(c:\a.xls
EmptyParam,EmptyParam,EmptyParam,EmptyParam,
EmptyParam,EmptyParam,EmptyParam,EmptyParam,
EmptyParam,EmptyParam,EmptyParam,EmptyParam,0)
7)
設置第2個工做表爲活動工做表:
ExcelApplication1.WorkSheets[2].Activate;
或
ExcelApplication1.WorksSheets[ 'Sheet2' ].Activate;
8)
給單元格賦值:
ExcelApplication1.Cells[1,4].Value := '第一行第四列';
9)
設置指定列的寬度(單位:字符個數),以第一列爲例:
ExcelApplication1.ActiveSheet.Columns[1].ColumnsWidth
:= 5;
10)
設置指定行的高度(單位:磅)(1磅=0.035釐米),以第二行爲例:
ExcelApplication1.ActiveSheet.Rows[2].RowHeight
:= 1/0.035; // 1釐米
11)
在第8行以前插入分頁符:
ExcelApplication1.WorkSheets[1].Rows.PageBreak := 1;
12)
在第8列以前刪除分頁符:
ExcelApplication1.ActiveSheet.Columns[4].PageBreak := 0;
13)
指定邊框線寬度:
ExcelApplication1.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight :=
3;
1-左 2-右 3-頂 4-底 5-斜( \ ) 6-斜( / )
14)
清除第一行第四列單元格公式:
ExcelApplication1.ActiveSheet.Cells[1,4].ClearContents;
15)
設置第一行字體屬性:
ExcelApplication1.ActiveSheet.Rows[1].Font.Name :=
'隸書';
ExcelApplication1.ActiveSheet.Rows[1].Font.Color :=
clBlue;
ExcelApplication1.ActiveSheet.Rows[1].Font.Bold :=
True;
ExcelApplication1.ActiveSheet.Rows[1].Font.UnderLine := True;
16)
進行頁面設置:
a.頁眉:
ExcelApplication1.ActiveSheet.PageSetup.CenterHeader :=
'報表演示';
b.頁腳:
ExcelApplication1.ActiveSheet.PageSetup.CenterFooter :=
'第&P頁';
c.頁眉到頂端邊距2cm:
ExcelApplication1.ActiveSheet.PageSetup.HeaderMargin :=
2/0.035;
d.頁腳到底端邊距3cm:
ExcelApplication1.ActiveSheet.PageSetup.HeaderMargin :=
3/0.035;
e.頂邊距2cm:
ExcelApplication1.ActiveSheet.PageSetup.TopMargin :=
2/0.035;
f.底邊距2cm:
ExcelApplication1.ActiveSheet.PageSetup.BottomMargin
:= 2/0.035;
g.左邊距2cm:
ExcelApplication1.ActiveSheet.PageSetup.LeftMargin :=
2/0.035;
h.右邊距2cm:
ExcelApplication1.ActiveSheet.PageSetup.RightMargin
:= 2/0.035;
i.頁面水平居中:
ExcelApplication1.ActiveSheet.PageSetup.CenterHorizontally :=
2/0.035;
j.頁面垂直居中:
ExcelApplication1.ActiveSheet.PageSetup.CenterVertically :=
2/0.035;
k.打印單元格網線:
ExcelApplication1.ActiveSheet.PageSetup.PrintGridLines := True;
17)
拷貝操做:
a.拷貝整個工做表:
ExcelApplication1.ActiveSheet.Used.Range.Copy;
b.拷貝指定區域:
ExcelApplication1.ActiveSheet.Range[ 'A1:E2' ].Copy;
c.從A1位置開始粘貼:
ExcelApplication1.ActiveSheet.Range.[ 'A1' ].PasteSpecial;
d.從文件尾部開始粘貼:
ExcelApplication1.ActiveSheet.Range.PasteSpecial;
18) 插入一行或一列:
a.
ExcelApplication1.ActiveSheet.Rows[2].Insert;
b.
ExcelApplication1.ActiveSheet.Columns[1].Insert;
19) 刪除一行或一列:
a.
ExcelApplication1.ActiveSheet.Rows[2].Delete;
b.
ExcelApplication1.ActiveSheet.Columns[1].Delete;
20)
打印預覽工做表:
ExcelApplication1.ActiveSheet.PrintPreview;
21)
打印輸出工做表:
ExcelApplication1.ActiveSheet.PrintOut;
22) 工做表保存:
if not
ExcelApplication1.ActiveWorkBook.Saved then
ExcelApplication1.ActiveSheet.PrintPreview;
23)
工做表另存爲:
ExcelApplication1.SaveAs( 'C:\Excel\Demo1.xls' );
24)
放棄存盤:
ExcelApplication1.ActiveWorkBook.Saved := True;
25)
關閉工做簿:
ExcelApplication1.WorkBooks.Close;
26) 退出
Excel:
ExcelApplication1.Quit;
ExcelApplication1.Disconnect;編程
對不起我還須要一個鎖定功能啊,就是輸出到EXCEL後只能看,不能進行手工修改數組
Xl.Cells.Select;//Select All Cells 服務器
Xl.Selection.Locked = True;// Lock Selected Cells微信
//Xl:=CreateOleObject('Excel.Application');app
引用 跨網段鏈接訪問 引用 Delphi操做EXCEL 2010-08-20 15:31:15| 分類: 默認分類 | 標籤: |舉報 |字號大 中 小 訂閱 用微信 「掃一掃」 將文章分享到朋友圈。 用易信 「掃一掃」 將文章分享到朋友圈。 下載LOFTER 個人照片書 | 本文轉載自有空來坐坐《Delphi操做EXCEL》 引用 有空來坐坐 的 Delphi操做EXCEL 轉自 上帝的魚--專欄 cdsn (最近用到這方面的資料,在網上找了一下,有些方法有待進一步確認) 我的收藏: Delphi 控制Excel (一) 使用動態建立的方法 首先建立 Excel 對象,使用ComObj: var ExcelApp: Variant; ExcelApp := CreateOleObject( 'Excel.Application' ); 1) 顯示當前窗口: ExcelApp.Visible := True; 2) 更改 Excel 標題欄: ExcelApp.Caption := '應用程序調用 Microsoft Excel'; 3) 添加新工做簿: ExcelApp.WorkBooks.Add; 4) 打開已存在的工做簿: ExcelApp.WorkBooks.Open( 'C:\Excel\Demo.xls' ); 5) 設置第2個工做表爲活動工做表: ExcelApp.WorkSheets[2].Activate; 或 ExcelApp.WorksSheets[ 'Sheet2' ].Activate; 6) 給單元格賦值: ExcelApp.Cells[1,4].Value := '第一行第四列'; 7) 設置指定列的寬度(單位:字符個數),以第一列爲例: ExcelApp.ActiveSheet.Columns[1].ColumnsWidth := 5; 8) 設置指定行的高度(單位:磅)(1磅=0.035釐米),以第二行爲例: ExcelApp.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1釐米 9) 在第8行以前插入分頁符: ExcelApp.WorkSheets[1].Rows.PageBreak := 1; 10) 在第8列以前刪除分頁符:ExcelApp.ActiveSheet.Columns[4].PageBreak := 0; 11) 指定邊框線寬度: ExcelApp.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3; 1-左 2-右 3-頂 4-底 5-斜( \ ) 6-斜( / ) 12) 清除第一行第四列單元格公式: ExcelApp.ActiveSheet.Cells[1,4].ClearContents; 13) 設置第一行字體屬性:ExcelApp.ActiveSheet.Rows[1].Font.Name := '隸書'; ExcelApp.ActiveSheet.Rows[1].Font.Color := clBlue; ExcelApp.ActiveSheet.Rows[1].Font.Bold := True; ExcelApp.ActiveSheet.Rows[1].Font.UnderLine := True; 14) 進行頁面設置: a.頁眉: ExcelApp.ActiveSheet.PageSetup.CenterHeader := '報表演示'; b.頁腳: ExcelApp.ActiveSheet.PageSetup.CenterFooter := '第&P頁'; c.頁眉到頂端邊距2cm: ExcelApp.ActiveSheet.PageSetup.HeaderMargin := 2/0.035; d.頁腳到底端邊距3cm: ExcelApp.ActiveSheet.PageSetup.HeaderMargin := 3/0.035; e.頂邊距2cm: ExcelApp.ActiveSheet.PageSetup.TopMargin := 2/0.035; f.底邊距2cm: ExcelApp.ActiveSheet.PageSetup.BottomMargin := 2/0.035; g.左邊距2cm: ExcelApp.ActiveSheet.PageSetup.LeftMargin := 2/0.035; h.右邊距2cm: ExcelApp.ActiveSheet.PageSetup.RightMargin := 2/0.035; i.頁面水平居中: ExcelApp.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035; j.頁面垂直居中: ExcelApp.ActiveSheet.PageSetup.CenterVertically := 2/0.035; k.打印單元格網線: ExcelApp.ActiveSheet.PageSetup.PrintGridLines := True; 15) 拷貝操做: a.拷貝整個工做表: ExcelApp.ActiveSheet.Used.Range.Copy; b.拷貝指定區域: ExcelApp.ActiveSheet.Range[ 'A1:E2' ].Copy; c.從A1位置開始粘貼: ExcelApp.ActiveSheet.Range.[ 'A1' ].PasteSpecial; d.從文件尾部開始粘貼: ExcelApp.ActiveSheet.Range.PasteSpecial; 16) 插入一行或一列: a. ExcelApp.ActiveSheet.Rows[2].Insert; b. ExcelApp.ActiveSheet.Columns[1].Insert; 17) 刪除一行或一列: a. ExcelApp.ActiveSheet.Rows[2].Delete; b. ExcelApp.ActiveSheet.Columns[1].Delete; 18) 打印預覽工做表: ExcelApp.ActiveSheet.PrintPreview; 19) 打印輸出工做表: ExcelApp.ActiveSheet.PrintOut; 20) 工做表保存: if not ExcelApp.ActiveWorkBook.Saved then ExcelApp.ActiveSheet.PrintPreview; 21) 工做表另存爲: ExcelApp.SaveAs( 'C:\Excel\Demo1.xls' ); 22) 放棄存盤: ExcelApp.ActiveWorkBook.Saved := True; 23) 關閉工做簿: ExcelApp.WorkBooks.Close; 24) 退出 Excel: ExcelApp.Quit; (二) 使用Delphi 控件方法 在Form中分別放入ExcelApplication, ExcelWorkbook和ExcelWorksheet。 1) 打開Excel ExcelApplication1.Connect; 2) 顯示當前窗口: ExcelApplication1.Visible[0]:=True; 3) 更改 Excel 標題欄: ExcelApplication1.Caption := '應用程序調用 Microsoft Excel'; 4) 添加新工做簿: ExcelWorkbook1.ConnectTo(ExcelApplication1.Workbooks.Add(EmptyParam,0)); 5) 添加新工做表: var Temp_Worksheet: _WorkSheet; begin Temp_Worksheet:=ExcelWorkbook1. WorkSheets.Add(EmptyParam,EmptyParam,EmptyParam,EmptyParam,0) as _WorkSheet; ExcelWorkSheet1.ConnectTo(Temp_WorkSheet);End; 6) 打開已存在的工做簿: ExcelApplication1.Workbooks.Open (c:\a.xls EmptyParam,EmptyParam,EmptyParam,EmptyParam, EmptyParam,EmptyParam,EmptyParam,EmptyParam, EmptyParam,EmptyParam,EmptyParam,EmptyParam,0) 7) 設置第2個工做表爲活動工做表: ExcelApplication1.WorkSheets[2].Activate; 或 ExcelApplication1.WorksSheets[ 'Sheet2' ].Activate; 8) 給單元格賦值: ExcelApplication1.Cells[1,4].Value := '第一行第四列'; 9) 設置指定列的寬度(單位:字符個數),以第一列爲例: ExcelApplication1.ActiveSheet.Columns[1].ColumnsWidth := 5; 10) 設置指定行的高度(單位:磅)(1磅=0.035釐米),以第二行爲例: ExcelApplication1.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1釐米 11) 在第8行以前插入分頁符: ExcelApplication1.WorkSheets[1].Rows.PageBreak := 1; 12) 在第8列以前刪除分頁符: ExcelApplication1.ActiveSheet.Columns[4].PageBreak := 0; 13) 指定邊框線寬度: ExcelApplication1.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3; 1-左 2-右 3-頂 4-底 5-斜( \ ) 6-斜( / ) 14) 清除第一行第四列單元格公式: ExcelApplication1.ActiveSheet.Cells[1,4].ClearContents; 15) 設置第一行字體屬性: ExcelApplication1.ActiveSheet.Rows[1].Font.Name := '隸書'; ExcelApplication1.ActiveSheet.Rows[1].Font.Color := clBlue; ExcelApplication1.ActiveSheet.Rows[1].Font.Bold := True; ExcelApplication1.ActiveSheet.Rows[1].Font.UnderLine := True; 16) 進行頁面設置: a.頁眉: ExcelApplication1.ActiveSheet.PageSetup.CenterHeader := '報表演示'; b.頁腳: ExcelApplication1.ActiveSheet.PageSetup.CenterFooter := '第&P頁'; c.頁眉到頂端邊距2cm: ExcelApplication1.ActiveSheet.PageSetup.HeaderMargin := 2/0.035; d.頁腳到底端邊距3cm: ExcelApplication1.ActiveSheet.PageSetup.HeaderMargin := 3/0.035; e.頂邊距2cm: ExcelApplication1.ActiveSheet.PageSetup.TopMargin := 2/0.035; f.底邊距2cm: ExcelApplication1.ActiveSheet.PageSetup.BottomMargin := 2/0.035; g.左邊距2cm: ExcelApplication1.ActiveSheet.PageSetup.LeftMargin := 2/0.035; h.右邊距2cm: ExcelApplication1.ActiveSheet.PageSetup.RightMargin := 2/0.035; i.頁面水平居中: ExcelApplication1.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035; j.頁面垂直居中: ExcelApplication1.ActiveSheet.PageSetup.CenterVertically := 2/0.035; k.打印單元格網線: ExcelApplication1.ActiveSheet.PageSetup.PrintGridLines := True; 17) 拷貝操做: a.拷貝整個工做表: ExcelApplication1.ActiveSheet.Used.Range.Copy; b.拷貝指定區域: ExcelApplication1.ActiveSheet.Range[ 'A1:E2' ].Copy; c.從A1位置開始粘貼: ExcelApplication1.ActiveSheet.Range.[ 'A1' ].PasteSpecial; d.從文件尾部開始粘貼: ExcelApplication1.ActiveSheet.Range.PasteSpecial; 18) 插入一行或一列: a. ExcelApplication1.ActiveSheet.Rows[2].Insert; b. ExcelApplication1.ActiveSheet.Columns[1].Insert; 19) 刪除一行或一列: a. ExcelApplication1.ActiveSheet.Rows[2].Delete; b. ExcelApplication1.ActiveSheet.Columns[1].Delete; 20) 打印預覽工做表: ExcelApplication1.ActiveSheet.PrintPreview; 21) 打印輸出工做表: ExcelApplication1.ActiveSheet.PrintOut; 22) 工做表保存: if not ExcelApplication1.ActiveWorkBook.Saved then ExcelApplication1.ActiveSheet.PrintPreview; 23) 工做表另存爲: ExcelApplication1.SaveAs( 'C:\Excel\Demo1.xls' ); 24) 放棄存盤: ExcelApplication1.ActiveWorkBook.Saved := True; 25) 關閉工做簿: ExcelApplication1.WorkBooks.Close; 26) 退出 Excel: ExcelApplication1.Quit; ExcelApplication1.Disconnect; 本人 收藏 對不起我還須要一個鎖定功能啊,就是輸出到EXCEL後只能看,不能進行手工修改 Xl.Cells.Select;//Select All Cells Xl.Selection.Locked = True;// Lock Selected Cells //Xl:=CreateOleObject('Excel.Application'); -------------------------------------------------------------------------------- procedure TForm1.BitBtn4Click(Sender: TObject); var ExcelApp, Sheet: Variant; begin if OpenDialog1.Execute then begin ExcelApp := CreateOleObject( 'Excel.Application' ); ExcelApp.Workbooks.Open(OpenDialog1.FileName); Sheet := ExcelApp.ActiveSheet; Caption := 'Row Count: ' + IntToStr(Sheet.UsedRange.Rows.Count); ExcelApp.Quit; Sheet := Unassigned; ExcelApp := Unassigned; end; end; -------------------------------------------------------------------------------- procedure CopyDbDataToExcel(Target: TDbgrid); var iCount, jCount: Integer; XLApp: Variant; Sheet: Variant; begin Screen.Cursor := crHourGlass; if not VarIsEmpty(XLApp) then begin XLApp.DisplayAlerts := False; XLApp.Quit; VarClear(XLApp); end; //經過ole建立Excel對象 try XLApp := CreateOleObject('Excel.Application'); except Screen.Cursor := crDefault; Exit; end; XLApp.WorkBooks.Add[XLWBatWorksheet]; XLApp.WorkBooks[1].WorkSheets[1].Name := '測試工做薄'; Sheet := XLApp.Workbooks[1].WorkSheets['測試工做薄']; if not Target.DataSource.DataSet.Active then begin Screen.Cursor := crDefault; Exit; end; Target.DataSource.DataSet.first; for iCount := 0 to Target.Columns.Count - 1 do begin Sheet.cells[1, iCount + 1] := Target.Columns.Items[iCount].Title.Caption; end; jCount := 1; while not Target.DataSource.DataSet.Eof do begin for iCount := 0 to Target.Columns.Count - 1 do begin Sheet.cells[jCount + 1, iCount + 1] := Target.Columns.Items[iCount].Field.AsString; end; Inc(jCount); Target.DataSource.DataSet.Next; end; XlApp.Visible := True; Screen.Cursor := crDefault; end; 看看個人函數 function ExportToExcel(Header: String; vDataSet: TDataSet): Boolean; var I,VL_I,j: integer; S,SysPath: string; MsExcel:Variant; begin Result:=true; if Application.MessageBox('您確信將數據導入到Excel嗎?','提示!',MB_OKCANCEL + MB_DEFBUTTON1) = IDOK then begin SysPath:=ExtractFilePath(application.exename); with TStringList.Create do try vDataSet.First ; S:=S+Header; // system.Delete(s,1,1); add(s); s:='; For I:=0 to vDataSet.fieldcount-1 do begin If vDataSet.fields[I].visible=true then S:=S+#9+vDataSet.fields[I].displaylabel; end; system.Delete(s,1,1); add(s); while not vDataSet.Eof do begin S := '; for I := 0 to vDataSet.FieldCount -1 do begin If vDataSet.fields[I].visible=true then S := S + #9 + vDataSet.Fields[I].AsString; end; System.Delete(S, 1, 1); Add(S); vDataSet.Next; end; Try SaveToFile(SysPath+'\Tem.xls'); Except ShowMessage('寫文件時發生保護性錯誤,Excel 如在運行,請先關閉!'); Result:=false; exit; end; finally Free; end; Try MSExcel:=CreateOleObject('Excel.Application'); Except ShowMessage('Excel 沒有安裝,請先安裝!'); Result:=false; exit; end; Try MSExcel.workbooks.open(SysPath+'\Tem.xls'); Except ShowMessage('打開臨時文件時出錯,請檢查'+SysPath+'\Tem.xls'); Result:=false; exit; end; MSExcel.visible:=True; for VL_I :=1 to 4 do MSExcel.Selection.Borders[VL_I].LineStyle := 0; MSExcel.cells.select; MSExcel.Selection.HorizontalAlignment :=3; MSExcel.Selection.Borders[1].LineStyle := 0; MSExcel.Range['A1'].Select; MSExcel.Selection.Font.Size :=24; J:=0 ; for i:=0 to vdataset.fieldcount-1 do if vDataSet.fields[I].visible then J:=J+1; VL_I :=J; MSExcel.Range['A1:'+F_ColumnName(VL_I)+'1'].Select; MSExcel.Range['A1:'+F_ColumnName(VL_I)+'1'].Merge; end else Result:=false; end; 轉別人的組件 unit OleExcel; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, comobj, DBTables, Grids; type TOLEExcel = class(TComponent) private FExcelCreated: Boolean; FVisible: Boolean; FExcel: Variant; FWorkBook: Variant; FWorkSheet: Variant; FCellFont: TFont; FTitleFont: TFont; FFontChanged: Boolean; FIgnoreFont: Boolean; FFileName: TFileName; procedure SetExcelCellFont(var Cell: Variant); procedure SetExcelTitleFont(var Cell: Variant); procedure GetTableColumnName(const Table: TTable; var Cell: Variant); procedure GetQueryColumnName(const Query: TQuery; var Cell: Variant); procedure GetFixedCols(const StringGrid: TStringGrid; var Cell: Variant); procedure GetFixedRows(const StringGrid: TStringGrid; var Cell: Variant); procedure GetStringGridBody(const StringGrid: TStringGrid; var Cell: Variant); protected procedure SetCellFont(NewFont: TFont); procedure SetTitleFont(NewFont: TFont); procedure SetVisible(DoShow: Boolean); function GetCell(ACol, ARow: Integer): string; procedure SetCell(ACol, ARow: Integer; const Value: string); function GetDateCell(ACol, ARow: Integer): TDateTime; procedure SetDateCell(ACol, ARow: Integer; const Value: TDateTime); public constructor Create(AOwner: TComponent); override; destructor Destroy; override; procedure CreateExcelInstance; property Cell[ACol, ARow: Integer]: string read GetCell write SetCell; property DateCell[ACol, ARow: Integer]: TDateTime read GetDateCell write SetDateCell; function IsCreated: Boolean; procedure TableToExcel(const Table: TTable); procedure QueryToExcel(const Query: TQuery); procedure StringGridToExcel(const StringGrid: TStringGrid); procedure SaveToExcel(const FileName: string); published property TitleFont: TFont read FTitleFont write SetTitleFont; property CellFont: TFont read FCellFont write SetCellFont; property Visible: Boolean read FVisible write SetVisible; property IgnoreFont: Boolean read FIgnoreFont write FIgnoreFont; property FileName: TFileName read FFileName write FFileName; end; procedure Register; implementation constructor TOLEExcel.Create(AOwner: TComponent); begin inherited Create(AOwner); FIgnoreFont := True; FCellFont := TFont.Create; FTitleFont := TFont.Create; FExcelCreated := False; FVisible := False; FFontChanged := False; end; destructor TOLEExcel.Destroy; begin FCellFont.Free; FTitleFont.Free; inherited Destroy; end; procedure TOLEExcel.SetExcelCellFont(var Cell: Variant); begin if FIgnoreFont then exit; with FCellFont do begin Cell.Font.Name := Name; Cell.Font.Size := Size; Cell.Font.Color := Color; Cell.Font.Bold := fsBold in Style; Cell.Font.Italic := fsItalic in Style; Cell.Font.UnderLine := fsUnderline in Style; Cell.Font.Strikethrough := fsStrikeout in Style; end; end; procedure TOLEExcel.SetExcelTitleFont(var Cell: Variant); begin if FIgnoreFont then exit; with FTitleFont do begin Cell.Font.Name := Name; Cell.Font.Size := Size; Cell.Font.Color := Color; Cell.Font.Bold := fsBold in Style; Cell.Font.Italic := fsItalic in Style; Cell.Font.UnderLine := fsUnderline in Style; Cell.Font.Strikethrough := fsStrikeout in Style; end; end; procedure TOLEExcel.SetVisible(DoShow: Boolean); begin if not FExcelCreated then exit; if DoShow then FExcel.Visible := True else FExcel.Visible := False; end; function TOLEExcel.GetCell(ACol, ARow: Integer): string; begin if not FExcelCreated then exit; result := FWorkSheet.Cells[ARow, ACol]; end; procedure TOLEExcel.SetCell(ACol, ARow: Integer; const Value: string); var Cell: Variant; begin if not FExcelCreated then exit; Cell := FWorkSheet.Cells[ARow, ACol]; SetExcelCellFont(Cell); Cell.Value := Value; end; function TOLEExcel.GetDateCell(ACol, ARow: Integer): TDateTime; begin if not FExcelCreated then begin result := 0; exit; end; result := StrToDateTime(FWorkSheet.Cells[ARow, ACol]); end; procedure TOLEExcel.SetDateCell(ACol, ARow: Integer; const Value: TDateTime); var Cell: Variant; begin if not FExcelCreated then exit; Cell := FWorkSheet.Cells[ARow, ACol]; SetExcelCellFont(Cell); Cell.Value := '' + DateTimeToStr(Value); end; procedure TOLEExcel.CreateExcelInstance; begin try FExcel := CreateOLEObject('Excel.Application'); FWorkBook := FExcel.WorkBooks.Add; FWorkSheet := FWorkBook.WorkSheets.Add; FExcelCreated := True; except FExcelCreated := False; end; end; function TOLEExcel.IsCreated: Boolean; begin result := FExcelCreated; end; procedure TOLEExcel.SetTitleFont(NewFont: TFont); begin if NewFont <> FTitleFont then FTitleFont.Assign(NewFont); end; procedure TOLEExcel.SetCellFont(NewFont: TFont); begin if NewFont <> FCellFont then FCellFont.Assign(NewFont); end; procedure TOLEExcel.GetTableColumnName(const Table: TTable; var Cell: Variant); var Col: integer; begin for Col := 0 to Table.FieldCount - 1 do begin Cell := FWorkSheet.Cells[1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := Table.Fields[Col].FieldName; end; end; procedure TOLEExcel.TableToExcel(const Table: TTable); var Col, Row: LongInt; Cell: Variant; begin if not FExcelCreated then exit; if Table.Active = False then exit; GetTableColumnName(Table, Cell); Row := 2; with Table do begin first; while not EOF do begin for Col := 0 to FieldCount - 1 do begin Cell := FWorkSheet.Cells[Row, Col + 1]; SetExcelCellFont(Cell); Cell.Value := Fields[Col].AsString; end; next; Inc(Row); end; end; end; procedure TOLEExcel.GetQueryColumnName(const Query: TQuery; var Cell: Variant); var Col: integer; begin for Col := 0 to Query.FieldCount - 1 do begin Cell := FWorkSheet.Cells[1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := Query.Fields[Col].FieldName; end; end; procedure TOLEExcel.QueryToExcel(const Query: TQuery); var Col, Row: LongInt; Cell: Variant; begin if not FExcelCreated then exit; if Query.Active = False then exit; GetQueryColumnName(Query, Cell); Row := 2; with Query do begin first; while not EOF do begin for Col := 0 to FieldCount - 1 do begin Cell := FWorkSheet.Cells[Row, Col + 1]; SetExcelCellFont(Cell); Cell.Value := Fields[Col].AsString; end; next; Inc(Row); end; end; end; procedure TOLEExcel.GetFixedCols(const StringGrid: TStringGrid; var Cell: Variant); var Col, Row: LongInt; begin for Col := 0 to StringGrid.FixedCols - 1 do for Row := 0 to StringGrid.RowCount - 1 do begin Cell := FWorkSheet.Cells[Row + 1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := StringGrid.Cells[Col, Row]; end; end; procedure TOLEExcel.GetFixedRows(const StringGrid: TStringGrid; var Cell: Variant); var Col, Row: LongInt; begin for Row := 0 to StringGrid.FixedRows - 1 do for Col := 0 to StringGrid.ColCount - 1 do begin Cell := FWorkSheet.Cells[Row + 1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := StringGrid.Cells[Col, Row]; end; end; procedure TOLEExcel.GetStringGridBody(const StringGrid: TStringGrid; var Cell: Variant); var Col, Row, x, y: LongInt; begin Col := StringGrid.FixedCols; Row := StringGrid.FixedRows; for x := Row to StringGrid.RowCount - 1 do for y := Col to StringGrid.ColCount - 1 do begin Cell := FWorkSheet.Cells[x + 1, y + 1]; SetExcelCellFont(Cell); Cell.Value := StringGrid.Cells[y, x]; end; end; procedure TOLEExcel.StringGridToExcel(const StringGrid: TStringGrid); var Cell: Variant; begin if not FExcelCreated then exit; GetFixedCols(StringGrid, Cell); GetFixedRows(StringGrid, Cell); GetStringGridBody(StringGrid, Cell); end; procedure TOLEExcel.SaveToExcel(const FileName: string); begin if not FExcelCreated then exit; FWorkSheet.SaveAs(FileName); end; procedure Register; begin RegisterComponents('Tanglu', [TOLEExcel]); end; end. ---------------------------------------------- 根據別人的組件改寫的支持ADO unit AdoToOleExcel; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, comobj, DBTables, Grids,ADODB; type TAdoToOleExcel = class(TComponent) private FExcelCreated: Boolean; FVisible: Boolean; FExcel: Variant; FWorkBook: Variant; FWorkSheet: Variant; FCellFont: TFont; FTitleFont: TFont; FFontChanged: Boolean; FIgnoreFont: Boolean; FFileName: TFileName; procedure SetExcelCellFont(var Cell: Variant); procedure SetExcelTitleFont(var Cell: Variant); procedure GetTableColumnName(const AdoTable: TAdoTable; var Cell: Variant); procedure GetQueryColumnName(const AdoQuery: TAdoQuery; var Cell: Variant); procedure GetFixedCols(const StringGrid: TStringGrid; var Cell: Variant); procedure GetFixedRows(const StringGrid: TStringGrid; var Cell: Variant); procedure GetStringGridBody(const StringGrid: TStringGrid; var Cell: Variant); protected procedure SetCellFont(NewFont: TFont); procedure SetTitleFont(NewFont: TFont); procedure SetVisible(DoShow: Boolean); function GetCell(ACol, ARow: Integer): string; procedure SetCell(ACol, ARow: Integer; const Value: string); function GetDateCell(ACol, ARow: Integer): TDateTime; procedure SetDateCell(ACol, ARow: Integer; const Value: TDateTime); public constructor Create(AOwner: TComponent); override; destructor Destroy; override; procedure CreateExcelInstance; property Cell[ACol, ARow: Integer]: string read GetCell write SetCell; property DateCell[ACol, ARow: Integer]: TDateTime read GetDateCell write SetDateCell; function IsCreated: Boolean; procedure ADOTableToExcel(const ADOTable: TADOTable); procedure ADOQueryToExcel(const ADOQuery: TADOQuery); procedure StringGridToExcel(const StringGrid: TStringGrid); procedure SaveToExcel(const FileName: string); published property TitleFont: TFont read FTitleFont write SetTitleFont; property CellFont: TFont read FCellFont write SetCellFont; property Visible: Boolean read FVisible write SetVisible; property IgnoreFont: Boolean read FIgnoreFont write FIgnoreFont; property FileName: TFileName read FFileName write FFileName; end; procedure Register; implementation constructor TAdoToOleExcel.Create(AOwner: TComponent); begin inherited Create(AOwner); FIgnoreFont := True; FCellFont := TFont.Create; FTitleFont := TFont.Create; FExcelCreated := False; FVisible := False; FFontChanged := False; end; destructor TAdoToOleExcel.Destroy; begin FCellFont.Free; FTitleFont.Free; inherited Destroy; end; procedure TAdoToOleExcel.SetExcelCellFont(var Cell: Variant); begin if FIgnoreFont then exit; with FCellFont do begin Cell.Font.Name := Name; Cell.Font.Size := Size; Cell.Font.Color := Color; Cell.Font.Bold := fsBold in Style; Cell.Font.Italic := fsItalic in Style; Cell.Font.UnderLine := fsUnderline in Style; Cell.Font.Strikethrough := fsStrikeout in Style; end; end; procedure TAdoToOleExcel.SetExcelTitleFont(var Cell: Variant); begin if FIgnoreFont then exit; with FTitleFont do begin Cell.Font.Name := Name; Cell.Font.Size := Size; Cell.Font.Color := Color; Cell.Font.Bold := fsBold in Style; Cell.Font.Italic := fsItalic in Style; Cell.Font.UnderLine := fsUnderline in Style; Cell.Font.Strikethrough := fsStrikeout in Style; end; end; procedure TAdoToOleExcel.SetVisible(DoShow: Boolean); begin if not FExcelCreated then exit; if DoShow then FExcel.Visible := True else FExcel.Visible := False; end; function TAdoToOleExcel.GetCell(ACol, ARow: Integer): string; begin if not FExcelCreated then exit; result := FWorkSheet.Cells[ARow, ACol]; end; procedure TAdoToOleExcel.SetCell(ACol, ARow: Integer; const Value: string); var Cell: Variant; begin if not FExcelCreated then exit; Cell := FWorkSheet.Cells[ARow, ACol]; SetExcelCellFont(Cell); Cell.Value := Value; end; function TAdoToOleExcel.GetDateCell(ACol, ARow: Integer): TDateTime; begin if not FExcelCreated then begin result := 0; exit; end; result := StrToDateTime(FWorkSheet.Cells[ARow, ACol]); end; procedure TAdoToOleExcel.SetDateCell(ACol, ARow: Integer; const Value: TDateTime); var Cell: Variant; begin if not FExcelCreated then exit; Cell := FWorkSheet.Cells[ARow, ACol]; SetExcelCellFont(Cell); Cell.Value := '' + DateTimeToStr(Value); end; procedure TAdoToOleExcel.CreateExcelInstance; begin try FExcel := CreateOLEObject('Excel.Application'); FWorkBook := FExcel.WorkBooks.Add; FWorkSheet := FWorkBook.WorkSheets.Add; FExcelCreated := True; except FExcelCreated := False; end; end; function TAdoToOleExcel.IsCreated: Boolean; begin result := FExcelCreated; end; procedure TAdoToOleExcel.SetTitleFont(NewFont: TFont); begin if NewFont <> FTitleFont then FTitleFont.Assign(NewFont); end; procedure TAdoToOleExcel.SetCellFont(NewFont: TFont); begin if NewFont <> FCellFont then FCellFont.Assign(NewFont); end; procedure TAdoToOleExcel.GetTableColumnName(const ADOTable: TADOTable; var Cell: Variant); var Col: integer; begin for Col := 0 to ADOTable.FieldCount - 1 do begin Cell := FWorkSheet.Cells[1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := ADOTable.Fields[Col].FieldName; end; end; procedure TAdoToOleExcel.ADOTableToExcel(const ADOTable: TADOTable); var Col, Row: LongInt; Cell: Variant; begin if not FExcelCreated then exit; if ADOTable.Active = False then exit; GetTableColumnName(ADOTable, Cell); Row := 2; with ADOTable do begin first; while not EOF do begin for Col := 0 to FieldCount - 1 do begin Cell := FWorkSheet.Cells[Row, Col + 1]; SetExcelCellFont(Cell); Cell.Value := Fields[Col].AsString; end; next; Inc(Row); end; end; end; procedure TAdoToOleExcel.GetQueryColumnName(const ADOQuery: TADOQuery; var Cell: Variant); var Col: integer; begin for Col := 0 to ADOQuery.FieldCount - 1 do begin Cell := FWorkSheet.Cells[1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := ADOQuery.Fields[Col].FieldName; end; end; procedure TAdoToOleExcel.ADOQueryToExcel(const ADOQuery: TADOQuery); var Col, Row: LongInt; Cell: Variant; begin if not FExcelCreated then exit; if ADOQuery.Active = False then exit; GetQueryColumnName(ADOQuery, Cell); Row := 2; with ADOQuery do begin first; while not EOF do begin for Col := 0 to FieldCount - 1 do begin Cell := FWorkSheet.Cells[Row, Col + 1]; SetExcelCellFont(Cell); Cell.Value := Fields[Col].AsString; end; next; Inc(Row); end; end; end; procedure TAdoToOleExcel.GetFixedCols(const StringGrid: TStringGrid; var Cell: Variant); var Col, Row: LongInt; begin for Col := 0 to StringGrid.FixedCols - 1 do for Row := 0 to StringGrid.RowCount - 1 do begin Cell := FWorkSheet.Cells[Row + 1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := StringGrid.Cells[Col, Row]; end; end; procedure TAdoToOleExcel.GetFixedRows(const StringGrid: TStringGrid; var Cell: Variant); var Col, Row: LongInt; begin for Row := 0 to StringGrid.FixedRows - 1 do for Col := 0 to StringGrid.ColCount - 1 do begin Cell := FWorkSheet.Cells[Row + 1, Col + 1]; SetExcelTitleFont(Cell); Cell.Value := StringGrid.Cells[Col, Row]; end; end; procedure TAdoToOleExcel.GetStringGridBody(const StringGrid: TStringGrid; var Cell: Variant); var Col, Row, x, y: LongInt; begin Col := StringGrid.FixedCols; Row := StringGrid.FixedRows; for x := Row to StringGrid.RowCount - 1 do for y := Col to StringGrid.ColCount - 1 do begin Cell := FWorkSheet.Cells[x + 1, y + 1]; SetExcelCellFont(Cell); Cell.Value := StringGrid.Cells[y, x]; end; end; procedure TAdoToOleExcel.StringGridToExcel(const StringGrid: TStringGrid); var Cell: Variant; begin if not FExcelCreated then exit; GetFixedCols(StringGrid, Cell); GetFixedRows(StringGrid, Cell); GetStringGridBody(StringGrid, Cell); end; procedure TAdoToOleExcel.SaveToExcel(const FileName: string); begin if not FExcelCreated then exit; FWorkSheet.SaveAs(FileName); end; procedure Register; begin RegisterComponents('Freeman', [TAdoToOleExcel]); end; end. -------------------------------------------------------------------------------- 數據導出爲Excel格式 首先要建立一個公共單元,名字大家能夠隨便起。 如下是我建立的公共單元的所有代碼: unit UnitDatatoExcel; interface uses Windows,Messages, SysUtils, Classes, Graphics, Controls, Forms,Dialogs, DB, ComObj; type TKHTMLFormatCellEvent = procedure(Sender: TObject; CellRow,CellColumn: Integer; FieldName: string; var CustomAttrs, CellData: string) of object; TDataSetToExcel = class(TComponent) private FDataSet: TDataSet; FOnFormatCell: TKHTMLFormatCellEvent; public constructor Create(AOwner: TComponent); override; destructor Destroy; override; procedure Transfer(const FileName: string; Title: string = '); published property DataSet: TDataSet read FDataSet write FDataSet; end; implementation constructor TDataSetToExcel.Create(AOwner: TComponent); begin inherited Create(AOwner); FDataSet := nil; end; destructor TDataSetToExcel.Destroy; begin inherited; end; procedure TDataSetToExcel.Transfer(const FileName:string;Title:string = '); var ExcelApp, MyWorkBook: Variant; i: byte; j, a: integer; s, k, b, CustomAttrs: string; begin try ExcelApp := CreateOleObject('Excel.Application'); MyWorkBook := CreateOleObject('Excel.Sheet'); except on Exception do raise exception.Create('沒法打開Excel文件,請確認已經安裝Execl') end; MyWorkBook := ExcelApp.WorkBooks.Add; MyWorkBook.WorkSheets[1].Range['A1:D1'].Merge(True); MyWorkBook.WorkSheets[1].Range['A1:D2'].HorizontalAlignment := $FFFFEFF4; MyWorkBook.WorkSheets[1].Cells[1, 1].Value := Title; with FDataSet do begin i := 2; for j := 0 to FieldCount - 1 do begin if Fields[j].Visible then begin b := Fields[j].DisplayLabel; CustomAttrs := '; if Assigned(FOnFormatCell) then FOnFormatCell(Self, 1, i, Fields[j].FieldName, CustomAttrs, b); MyWorkBook.WorkSheets[1].Cells[i, j + 1].Value := b; end; end; i := 3; Close; Open; First; a := 2; while not Eof do begin for j := 0 to FieldCount - 1 do begin if Fields[j].Visible then begin CustomAttrs := '; k := Fields[j].Text; if Assigned(FOnFormatCell) then FOnFormatCell(Self, i, a, Fields[j].FieldName, CustomAttrs, k); MyWorkBook.WorkSheets[1].Cells[i, j + 1].Value := k; inc(a); end; end; Inc(i); Next; end; end; s := 'A3:D' + IntToStr(i - 1); s := 'A1:D' + IntToStr(i - 1); MyWorkBook.WorkSheets[1].Columns[1].ColumnWidth := 20; MyWorkBook.WorkSheets[1].Columns[4].ColumnWidth := 25; MyWorkBook.WorkSheets[1].Rows[1].RowHeight := 50; MyWorkBook.WorkSheets[1].Rows[1].VerticalAlignMent := $FFFFEFF4; MyWorkBook.WorkSheets[1].Range[s].Font.Name := '仿宋'; s := 'A2:D' + IntToStr(i - 1); MyWorkBook.WorkSheets[1].Range[s].Borders.LineStyle := 1; MyWorkBook.WorkSheets[1].PageSetup.CenterHorizontally := True; MyWorkBook.WorkSheets[1].PageSetup.PrintTitleRows := 'A1'; try MyWorkBook.Saveas(FileName); MyWorkBook.Close; except MyWorkBook.Close; end; ExcelApp.Quit; ExcelApp := UnAssigned; end; end. 而後在調用它的單元裏引用它就好了。 下面是調用它的代碼: procedure ToGetherExcel(NewData: TDataSet; NewString: string); var DataExcel: TDataSetToExcel; saveDlg: TSaveDialog; begin saveDlg := TSaveDialog.Create(nil); //建立一個存儲對話框 DataExcel := TDataSetToExcel.Create(nil); try saveDlg.Filter := 'Execl 文件(*.XLS)|*.XLS'; saveDlg.DefaultExt := 'XLS'; saveDlg.FileName := NewString; if saveDlg.Execute then begin DataExcel.DataSet := NewData; //鏈接的數據集 DataExcel.DataSet.DisableControls; DataExcel.Transfer(saveDlg.FileName, NewString); DataExcel.DataSet.EnableControls; AlterMesg('導出完畢', '提示信息'); end; finally saveDlg.Free; DataExcel.Free; end; end; 若是誰還有比着更好的辦法,請告訴我,我們共同進步:) -------------------------------------------------------------------------------- 我給大夥發一個吧,調用過程,很方便, 這裏DBGrid可更改成Query等與數據庫相關的 procedure DBTOExcel(sDBGrid: DBGrid; Title,Fn: string); //uses ComObj; //sDBGrid:數據源 //Title:標題 //Fn:保存文件 var ExcelApp: Variant; i,j,k: Integer; __ColStr,__s:String; begin try ExcelApp := CreateOleObject('Excel.Application'); except //on Exception do raise exception.Create('沒法建立Xls文件,請確認是否安裝EXCEL'); application.MessageBox('系統中的MS Excel軟件沒有安裝或安裝不正確!', '錯誤', MB_ICONERROR + MB_OK); exit; end; ExcelApp.visible := False; ExcelApp.WorkBooks.Add; ExcelApp.caption := Title; __ColStr:=Chr(65+sDBGrid.FieldCount-1); ExcelApp.worksheets[1].range['A1:'+__ColStr+'1'].Merge(True); //寫入標題行 ExcelApp.Cells[1, 1].Value := Title; ExcelApp.worksheets[1].range['A1:'+__ColStr+'3'].HorizontalAlignment := $FFFFEFF4; ExcelApp.worksheets[1].range['A1:'+__ColStr+'3'].VerticalAlignment := $FFFFEFF4; ExcelApp.worksheets[1].range['A2:B2'].Merge(True); ExcelApp.worksheets[1].range['C2:D2'].Merge(True); ExcelApp.Cells[2, 1].Value := '製表人:'+Myvalue.FUserName; ExcelApp.Cells[2, 3].Value := '製表日期:'+DateToStr(Date()); for i := 1 to sDBGrid.FieldCount do begin //各個字段的寬度 ExcelApp.worksheets[1].Columns[i].ColumnWidth:=sDBGrid.Fields[i-1].DisplayWidth; //字段標題 ExcelApp.Cells[3, i].Value := sDBGrid.Columns[i-1].Title.caption; end; ExcelApp.worksheets[1].Range['A1:'+__ColStr+'1'].Font.Name := '黑體'; ExcelApp.worksheets[1].Range['A1:'+__ColStr+'1'].Font.Size := 16; ExcelApp.worksheets[1].range['A1:'+__ColStr+'3'].font.bold:=true; ExcelApp.worksheets[1].Range['A2:'+__ColStr+'3'].Font.Size := 10; i := 4; k := 0; sDBGrid.DataSource.DataSet.First; while not sDBGrid.DataSource.DataSet.Eof do begin for j := 0 to sDBGrid.FieldCount - 1 do begin ExcelApp.Cells[i, j + 1].Value := sDBGrid.Fields[j].AsString; end; sDBGrid.DataSource.DataSet.Next; i := i + 1; k:=k+1; __s:= 'A3:'+__ColStr+IntToStr(i-1); end; sDBGrid.DataSource.DataSet.First; ExcelApp.worksheets[1].Range[__s].HorizontalAlignment := $FFFFEFF4; ExcelApp.worksheets[1].Range[__s].VerticalAlignment := $FFFFEFF4; ExcelApp.worksheets[1].Range[__s].Font.Name := '宋體'; ExcelApp.worksheets[1].Range[__s].Font.Size := 10; ExcelApp.worksheets[1].Range[__s].Borders.LineStyle := 1; ExcelApp.ActiveSheet.PageSetup.RightMargin := 0.5/0.035; ExcelApp.ActiveSheet.PageSetup.LeftMargin := 2/0.035; ExcelApp.ActiveSheet.PageSetup.BottomMargin := 0.5/0.035; ExcelApp.visible := True; ExcelApp.ActiveCell.Cells.Select; ExcelApp.Selection.Columns.AutoFit; try ExcelApp.ActiveWorkBook.SaveAs(Fn); except end; end; //導出數據到Excel procedure ToExcel(DBGrid:TDBGrid); var ExcelApp: Variant; i,j,k:integer; FileName:string; DlgSave:TsaveDialog; Begin DlgSave:=TsaveDialog.Create(nil); DlgSave.Filter:='*.xls|*.xls'; if DlgSave.Execute then Begin application.ProcessMessages; Filename:=DlgSave.FileName; ExcelApp := CreateOleObject( 'Excel.Application' ); ExcelApp.Caption :='能創監控系統日誌數據';//'Microsoft Excel'; ExcelApp.WorkBooks.Add; application.ProcessMessages; ExcelApp.WorkSheets[1].Activate; K:=1; For i:=0 To DBGrid.Columns.Count-1 Do Begin if DBGrid.Columns[i].Visible Then Begin ExcelApp.Cells[1,K]:=DBGrid.Columns[i].Title.Caption; k:=k+1; End;{if} End;{for} ExcelApp.rows[1].font.name:='宋體'; ExcelApp.rows[1].font.size:=10; ExcelApp.rows[1].Font.Color:=clBlack; ExcelApp.rows[1].Font.Bold:=true; j:=1; For i:=0 To DBGrid.Columns.Count-1 Do Begin If DBGrid.Columns[i].Visible Then Begin ADOQuery_DB.First; for k:=1 To ADOQuery_DB.RecordCount-1 Do Begin ExcelApp.Cells[K+1,j]:=ADOQuery_DB.FieldByName(DBGrid.Columns[i].FieldName).Asstring; ADOQuery_DB.Next; End;{for} j:=j+1; End;{if} End;{for} For I:=1 To ADOQuery_DB.recordcount Do ExcelApp.rows[i].Font.SIZE:=9; ExcelApp.Columns.AutoFit; ExcelApp.ActiveWorkBook.SaveAs(FileName); ExcelApp.WorkBooks.Close; Application.MessageBox('數據導出成功....','數據導出',0); ExcelApp.Quit; ExcelApp:=Unassigned; DlgSave.Destroy; End; end; 測試經過! -------------------------------------------------------------------------------- 我能夠發一段給你 先在程序上放上三個控件,TExcelApplication,TExcelWorkbook,TExcelWorkSheet,它們都在Server組件板上。 要控制Excel,就是採用自動化編程。以Excel做爲自動化服務器。 首先,創建與自動化服務器的鏈接: Excelapplication1.Connect; Excelapplication1.Visible[0]:=true; Excelapplication1.Caption:='你要的標題'; ExcelWorkbook1.ConnectTo(Excelapplication1.Workbooks.Add(null,0) ); Excelworksheet1.ConnectTo(Excelworkbook1.Worksheets[0] as _worksheet) ; 而後就能夠對Excel進行控件了: 從數據庫導入數據: Excel.cells.item[row,col]:=table1.field[i].value; .... 最後不要忘了斷開鏈接 Excelapplication1.disconnect; Excelapplication1.quit; 至今是delphi菜鳥 ****************************************************************** 如何把在dbgrid的指定幾列導到excel表裏? 個人作法:用listbox1顯示dbgrid的所用供選擇列,listbox2用來顯示要導出的列: procedure TForm1.FormCreate(Sender: TObject); begin if kadaoTable1.Active then kadaoTable1.GetFieldNames(Listbox1.Items); end; procedure TForm1.addbitbtnClick(Sender: TObject);//選擇字段 begin try if listbox1.Items.Count=0 then exit; if listbox1.Selected[listbox1.ItemIndex] then begin Listbox2.Items.Add(Listbox1.Items[Listbox1.ItemIndex]); Listbox1.Items.Delete(Listbox1.ItemIndex); if Listbox2.Items.Count>=1 then DeleteBitBtn.Enabled:=True; end; except showmessage('你沒有選擇相應字段!'); end; end; procedure TForm1.DeleteBitBtnClick(Sender: TObject);//撤消選擇 begin try if Listbox2.Items.Count=0 then exit; if listbox2.Selected[Listbox2.ItemIndex] then begin Listbox1.Items.Add(Listbox2.items[Listbox2.itemindex]); Listbox2.Items.Delete(Listbox2.itemindex); end; if Listbox2.Items.Count=0 then DeleteBitBtn.Enabled:=False; except showmessage('你沒有選擇相應字段!'); end; end; procedure CopyDbDataToExcel(Args: array of const); var iCount, jCount: Integer; XLApp: Variant; Sheet: Variant; I: Integer; begin Screen.Cursor := crHourGlass; if not VarIsEmpty(XLApp) then begin XLApp.DisplayAlerts := False; XLApp.Quit; VarClear(XLApp); end; try XLApp := CreateOleObject('excel.Application'); except Screen.Cursor := crDefault; Exit; end; XLApp.WorkBooks.Add; XLApp.SheetsInNewWorkbook := High(Args) + 1; for I := Low(Args) to High(Args) do begin XLApp.WorkBooks[1].WorkSheets[I+1].Name := TDBGrid(Args[I].VObject).Name; Sheet := XLApp.Workbooks[1].WorkSheets[TDBGrid(Args[I].VObject).Name]; if not TDBGrid(Args[I].VObject).DataSource.DataSet.Active then begin Screen.Cursor := crDefault; Exit; end; TDBGrid(Args[I].VObject).DataSource.DataSet.first; for iCount := 0 to TDBGrid(Args[I].VObject).Columns.Count - 1 do Sheet.Cells[1, iCount + 1] := TDBGrid(Args[I].VObject).Columns.Items[iCount].Title.Caption; jCount := 1; while not TDBGrid(Args[I].VObject).DataSource.DataSet.Eof do begin for iCount := 0 to TDBGrid(Args[I].VObject).Columns.Count - 1 do Sheet.Cells[jCount + 1, iCount + 1] := TDBGrid(Args[I].VObject).Columns.Items[iCount].Field.AsString; Inc(jCount); TDBGrid(Args[I].VObject).DataSource.DataSet.Next; end; end; XlApp.Visible := True; Screen.Cursor := crDefault; end; procedure TForm1.BitBtn3Click(Sender: TObject);//導出操做 begin CopyDbDataToExcel([DBGrid4]); end; 我 想解決問題有兩種辦法:1、直接修改CopyDbDataToExcel。2、實現dbgrid4顯示的字段列與listbox2中字段同步, dbgrid4中的其他字段要刪除掉,不是隱藏。也就是用listbox2中字段來控制哪些字段導入到excel表中呀,如何實現呀? 請高手指點! ***************************** 將dbgrid中數據導出到excel後,如何編寫程序使excel的列寬調整爲最適合的列寬? ExcelWorkSheet1.Columns.AutoFit; ************************************ var s:string; i,j:integer; begin s:='d:\aa\aa.xls'; //文件名 if fileexists(s) then deletefile(s); v:=CreateOLEObject('Excel.Application'); //創建OLE對象 V.WorkBooks.Add; if Checkbox1.Checked then begin V.Visible:=False; //使Excel可見,並將本程序最小化,以觀察Excel的運行狀況 end else begin V.Visible:=True; //True end; //使Excel窗口不可見 //Application.BringToFront; //程序前置 try try Cursor:=crSQLWait; query1.DisableControls; For i:=0 to query1.FieldCount-1 do //字段數 //注意:Delphi中的數組的下標是從0開始的, // 而Excel的表格是從1開始編號 begin V.Goto('R1'+'C'+IntToStr(i+1)); //Excel的表格是從1開始編號 V.ActiveCell.FormulaR1C1:=query1.Fields[i].FieldName;//傳送字段名 end; j:=2; query1.First; while not query1.EOF do begin For i:=0 to query1.FieldCount-1 do //字段數 begin V.Goto('R'+IntToStr(j)+'C'+IntToStr(i+1)); V.ActiveCell.FormulaR1C1:=query1.Fields[i].AsString;//傳送內容 end; query1.Next; j:=j+1; end; //設置保護 ShowMessage('數據庫到Excel的數據傳輸完畢!'); except //發生錯誤時 ShowMessage('沒有發現Excel!'); end; finally Cursor:=crDefault; query1.First; query1.EnableControls; end; end; //和上面的差很少,不過不是從DBGrid中導出的!上面的也不是,只是從Query中 導出來。我也想知從DBGrid 中怎麼樣導出來,或直接打印也行! ************************************************ 直接使用Excel對象,它是標準的COM對象,能夠在Delphi中引用的。 我給你一個函數: function ExportDataToExcel(cds: TClientDataSet; dbGrid: TDBGrid; ExcelAppData: TExcelApplication; Title, strWhere: String): Boolean; var sheet,Range: Variant; i,j: Integer; str,fVal: String; begin Result := False; if (cds = nil) or (not cds.Active) then Exit; try if ExcelAppData.Tag = 1 then begin ExcelAppData.Disconnect; ExcelAppData.Tag := 0; end; ExcelAppData.Connect; ExcelAppData.Visible[0] := True; ExcelAppData.Tag := 1; except ShowMessage('啓動Excel失敗,Excel可能沒有安裝。'); Abort; end; cds.DisableControls; try if Trim(Title) = ' then Title := '查詢結果'; ExcelAppData.Caption := Title; ExcelAppData.Workbooks.Add(emptyparam,0); sheet := ExcelAppData.Workbooks[ExcelAppData.Workbooks.Count].Worksheets[1]; sheet.name := Title; i := (dbGrid.Columns.Count div 2) - 1; if i < 1 then i:=1; Sheet.Cells[1,i] := Title; ExcelAppData.StandardFontSize[0] := 9; //設置表格字體 if dbGrid.Columns.Count < 24 then begin str := Char(Ord('A') + dbGrid.Columns.Count -1); // 計算最後一列的列標 Range := Sheet.Range['A3:' + str + '3']; //取出表頭的邊界 Range.Columns.Interior.ColorIndex := 8; //設置表頭的顏色 //計算表格區域 str := 'A3:' + str + IntToStr(cds.RecordCount + 3); Range := Sheet.Range[str]; //取出表格數據區域邊界 Range.Borders.LineStyle := xlContinuous; // 設置表格的線條 end; Sheet.Cells[2,1] := strWhere;//'日期:' + DateToStr(Date); //寫表頭 for j := 0 to dbGrid.Columns.Count -1 do begin Sheet.Cells[3,j + 1] := dbGrid.Columns.Items[j].Title.Caption; Sheet.Columns.Columns[j+1].ColumnWidth := dbGrid.Columns.Items[j].Width div 6; end; //寫表的內容 cds.First; for i:= 4 to cds.RecordCount + 3 do begin for j := 0 to dbGrid.Columns.Count - 1 do begin fVal := Trim(cds.FieldByName(dbGrid.Columns.Items[j].FieldName).AsString); Sheet.Cells[i,j + 1] := fVal; end; cds.Next; end; Sleep(1000); //延時1秒,等待Excel處理完成 Result := True; except on E: Exception do ShowMessage('數據導出時出現異常!' + E.Message); end; ExcelAppData.Disconnect; cds.EnableControls; end;