中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Delphi > 综合文章
Delphi 与 Excel (二)
作者:未知 时间:2004-10-09 12:12 出处:Blog 责编:chinaitpower
              摘要:暂无

////////////////////////////////    Excel 的一个宏  ///////////////////////////////////
Sub setpageinfo(ByVal regDateStr As String)

    Dim I, maxRow As Integer
   
    '取得最大行 maxRow
    Range("A1").Select
    ActiveCell.SpecialCells(xlLastCell).Select
    maxRow = ActiveCell.Row
   
    '取得有日期的行
    I = maxRow
    Range("A1").Select
    While (Range("A" & CStr(I)).Value <> "dateLine") And (I >= 1)
      'If Range("A" & CStr(I)).Value = "change1" Then
      '  Rows(CStr(I) & ":" & CStr(I)).RowHeight = 21
      'End If
      I = I - 1
    Wend
    '写入日期
    Range("G" & CStr(I)).Select
    ActiveCell.FormulaR1C1 = buyDateStr
   
    '删除 A 列
    Columns("A:A").Select
    Selection.Delete Shift:=xlToLeft
    Range("A1").Select
 
End Sub

////////////////////////////////    Delphi   ///////////////////////////////////
uses comobj,excel97;

function ToExcelReport(dxSourceList: TdxTreeList):boolean;
var XLApp,workbook,sheet:Variant; I_Row,I_Father,I_Child,I,J:integer;
begin
   result:=true;
   try
   if not VarIsEmpty(XLApp) then begin
      XLApp.displayAlerts:=false;
      XLApp.quit;
   end;

  
(1) {---  打开 Excel 文件 ----}
   XLApp:=createOleObject('Excel.Application');  
   XLApp.WorkBooks.Add(A_FileName);  //A_FileName:一个已存在的文件
   workbook := XLApp.workbooks[1];
   sheet:=workbook.worksheets[1];
    XLApp.displayAlerts:=false;
    XLApp.ScreenUpdating:=true;
(2) {---  创建新 Excel 文件 ----}
   XLApp:=createOleObject('Excel.Application');

   //XLApp.visible:=true;
   XLApp.WorkBooks.Add(xlWBatWorkSheet);    // new workSheet
   XLApp.WorkBooks[1].worksheets[1].name:='NewWorkSheet';
   workbook := XLApp.workbooks[1];
   sheet:=workbook.worksheets[1];
    XLApp.displayAlerts:=false;
    XLApp.ScreenUpdating:=true;

   I_Father:=dxSourceList.Count ; I_Row:=1;
   for I:=0 to I_Father-1 do begin
      I_Child:=dxSourceList.items[I].Count ;
      sheet.cells[I_Row,1]:=dxSourceList.items[I].strings[0];
      I_Row:=I_Row+1;
      for J:=0 to I_Child-1 do begin
         sheet.cells[I_Row,1]:=dxSourceList.items[I].items[J].strings[0];
         I_Row:=I_Row+1;
      end;
   end;
  
    //运行宏
    //XLApp.run('macroName',params...)
    //workbook.save ;
    workBook.SaveAs(AFileName,xlNormal,'','',False,False);
   XLApp.visible:=true;
   except
      result:=false;
   end;
end;

procedure Tform1.FormCloseQuery(Sender: TObject; var CanClose: Boolean);
begin
   if not VarIsEmpty(XLApp) then begin
      XLApp.displayAlerts:=false;
      XLApp.quit;
   end;
end;

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有