请问有如何检测EXCEL表格中是否存在数据透视表或统计作图,表中统计的细节是否可以导出?

解决方案 »

  1.   

    用adoquery连接execl,设置sql属性:select * from 表,然后判断adoquery.Recordcount是否等于0,
    呵呵,大致就应该是这了,具体自己查书做!
      

  2.   

    谢谢 nyf1220和vagerent。我做的是一个批改学生作业的改卷系统,学生已经完成了对EXCEL数据表的数据透视表操作。我要用DELPHI对其进行批改,好象查不到这方面的资料。nyf1220的方法应该不适用这种情况吧。
      

  3.   

    首先创建 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[8].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;
      

  4.   

    (二) 使用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[8].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;
    (三) 使用Delphi 控制Excle二维图
    在Form中分别放入ExcelApplication, ExcelWorkbook和ExcelWorksheet
    var asheet1,achart, range:variant;
    1)选择当第一个工作薄第一个工作表
    asheet1:=ExcelApplication1.Workbooks[1].Worksheets[1];
    2)增加一个二维图
    achart:=asheet1.chartobjects.add(100,100,200,200);
    3)选择二维图的形态
    achart.chart.charttype:=4;
    4)给二维图赋值
    series:=achart.chart.seriescollection;
    range:=sheet1!r2c3:r3c9;
    series.add(range,true);
       5)加上二维图的标题
    achart.Chart.HasTitle:=True;
    achart.Chart.ChartTitle.Characters.Text:=’ Excle二维图’ 
    6)改变二维图的标题字体大小
    achart.Chart.ChartTitle.Font.size:=6;
    7)给二维图加下标说明
    achart.Chart.Axes(xlCategory, xlPrimary).HasTitle := True;
    achart.Chart.Axes(xlCategory, xlPrimary).AxisTitle.Characters.Text := '下标说明';
    8)给二维图加左标说明
    achart.Chart.Axes(xlValue, xlPrimary).HasTitle := True;
    achart.Chart.Axes(xlValue, xlPrimary).AxisTitle.Characters.Text := '左标说明';
    9)给二维图加右标说明
    achart.Chart.Axes(xlValue, xlSecondary).HasTitle := True;
    achart.Chart.Axes(xlValue, xlSecondary).AxisTitle.Characters.Text := '右标说明';
    10)改变二维图的显示区大小
    achart.Chart.PlotArea.Left := 5;
    achart.Chart.PlotArea.Width := 223;
    achart.Chart.PlotArea.Height := 108;
    11)给二维图坐标轴加上说明
    achart.chart.seriescollection[1].NAME:='坐标轴说明';
      

  5.   

    xinshiji,你的回答好象跟我的问题无关?
      

  6.   

    呵呵,楼上的那位提供的函数是 操作 excel 表的,不过确实和你的关系不太大
    这个到是没有做过 ……
      

  7.   

    是的,现在查到的资料多数是如何操作EXCEL表格的函数,对于一些比较深层次的应用,有无其他网站可以交流?
      

  8.   

    在DELPHI中写VBA宏代码不过技术上有点深具体的你可以看看EXCEL中对VBA的调用和使用帮组.原理就是在程序打开EXCEL表时用EXCEL的自动宏去检测有无数据集或者数据表间的关联!
      

  9.   

    谢谢COOLFILM,请问什么是自动宏,需要做什么设置吗?
      

  10.   

    自动宏就是在EXCEL表格模板打开的时候加载的!EXCEL帮助里边有DEMO.你也可以在EXCEL里先生成宏代吗.然后在DELPHI中调用.
      

  11.   

    Delphi与excel之间的融合技术  一、VBA代码含义
    Microsoft excel是一个集成化环境,是美国微软公司的字处理系统,但是它决不仅仅是一个字处理系统,它集成了Microsoft Visual Basic,可以通过编程来实现对excel功能的扩展。Microsoft Visual Basic在excel中的代码即excel的宏,通过编写excel宏,可实现一些文档处理的自动化,如实现文档的自动备份、存盘等,可扩展excel文档的功能,因此,能够充分利用excel的特性,甚至使excel成为自己软件的一部分。excel的宏既有有利的一部分,因为它能够帮助我们实现文档的自动化,但是excel的宏也不是纯粹的有利,有时它可能危害我们的文档、计算机系统甚至网络,从最开始的Taiwan NO1宏病毒到现在的Melissa宏病毒,从最开始的简单的提示,耗尽系统资源到现在的乱发电子邮件,将个人的信息发送到网络上,甚至向硬盘的Autoexec.bat(自动批处理文件)中添加Deltree C: -y,破坏整个Windows系统。二、excel中内嵌的Com技术
    可以说excel是对Com技术支持最好的软件,这样说似乎是太极端了一点,但是excel提供的强大的编程接口技术却能够是我们通过程序控制excel的任何一部分。无论是文件的打开、存盘、打印还是文档中表格的自动绘制。通过编程软件,可以灵活的操纵excel,这里只以Borland Delphi为例,进行详细描述:
    1、 在Delphi中调用excel软件/文件的方法
    在excel中调用excel软件,归纳起来有三种方法:
    。通过Delphi的控件TOleContainer 将excel嵌入
    a.使用Delphi提供的Servers控件调用excel,使用excel的属性
    b.通过真正的Com技术,将Office软件目录中文件MSexcel9.OLB中的类库全部导入Delphi中,利用Com技术编程
    c.使用CreateOleObject将启动excel,然后以Ole方式对excel进行控制。2、 对几种方法的难易程度的判别
    a.通过Delphi的控件TOleContainer 将excel嵌入这是最简单的Ole嵌入,能够直接将excel文档调用,只需要使用ToleContainer.Run就可以将excel文档直接启动。且这样启动的excel文档与Delphi程序是一个整体(从界面上看),但是它存在不可克服的缺点,即不能通过Delphi控制excel文档,也就不能实现将灵活操纵excel的目的。b.使用Delphi提供的Servers控件调用excel,使用excel的属性
    使用Delphi的Servers控件来操纵excel,在编程时Delphi能够实现代码提示,总体上看能够较好的实现Delphi对excel的控制,但是还有一些excel的功能不能在Delphi中调用(比如自己编写的VBA宏代码)。且实现功能时本来在VBA代码中可选则参数在Delphi调用的时候必须添加,否则,连编译都不能通过。本方式启动的excel与Delphi程序分属两个窗体。此办法仅能作为一个参考。c.通过真正的Com技术,将Office软件目录中文件MSexcel9.OLB中的类库全部导入Delphi中,利用Com技术编程利用真正的Com技术,将Msexcel9.OLD文件类库导入,然后利用Com技术进行使用。整体上类似使用Delphi的Servers控件,稍微比Servers控件麻烦,优缺点与Servers控件相同。d.使用CreateOleObject将启动excel,然后以Ole方式对excel进行控制。本办法是使用以CreateOleObjects方式调用excel,实际上还是Ole,但是这种方式能够真正做到完全控制excel文件,能够使用excel的所有属性,包括自己编写的VBA宏代码。与Servers控件和com技术相比,本方法能够真正地使用excel的各种属性,和在VBA中编写自己的代码基本一样,可以缺省的代码也不需要使用。
    本方式启动的excel与Delphi程序分属两个窗体。缺点是使用本方法没有Delphi代码提示,所有异常处理均需要自己编写,可能编写时探索性知识比较多。三、excel宏编辑器
    excel能够真正地进行VBA代码的编辑,可以编写窗体、函数。进入excel宏编辑器的方法:工具->宏->Visual Basic编辑器,可进入Visual Basic编辑器界面。excel的Visual Basic编辑器界面和真正的Visual Basic编辑器基本相同,在此不再向详述。在VBA代码中,可以添加用户窗体、模块、类模块。用户窗体、模块、类模块的概念和Visual Basic完全相同。注释也与Visual Basic完全相同。可以将光标停留在窗体、模块的任何一个子程序上,直接按“F5”运行当前子程序。四、excel的宏的概述
    excel充分地将文档编辑和VB结合起来,真正地实现文档的自动化。使用excel编程,类似于使用Visual Basic,所不同的是,在excel中,能够直接运行某一个子程序,直接看见结果,excel的宏,只能解释运行,而Visual Basic,现在已经能够编写成真正的机器码,从代码的保护上来说,应该尽可能地减少excel的VBA代码数量,尤其是关键的代码。
    VBA宏,可分成四种:
    1、 和命令名相同的宏
    如FileSave,FileOpen,如果在VBA代码中包含与excel同名的函数,则直接执行这些VBA代码,忽略excel本身的命令。
    2、 excel内特定的宏
    这些宏包含AutoExec(启动 excel 或加载全局模板)、AutoNew(每次新建文档时)、AutoOpen(每次打开已有文档时)、AutoClose(每次关闭文档时),AutoExit(退出 excel 或卸载全局模板时)。如果VBA代码中含有这些名称的函数,则满足相应的条件,相应代码就自动执行。
    3、 相应事件的VBA宏
    这些宏是由事件触发的宏,如Document_Close在文档关闭的时候触发事件,Document_New在新建文档的时候触发,Document_Open在打开文档的时候触发。
    4、 独立的宏
    自己编写的VBA代码,即不属于上面几种情况的VBA代码,可以被其他VBA代码调用,更重要的是,可以被其他程序调用。这样,我们就可以屏弃excel自动执行的宏,通过Delphi直接调用相应宏来达到目的。
    五、excel命令宏的详细描述
    excel本身的命令函数包含很多,但是无论是excel联机帮助还是MSDN帮助,都没有这方面的介绍,因此只能凭自己的实验取探索,初步探测的函数如下:
    宏名 解释 注释
    FileNew 新建 
    FileNewDefault 新建空白文档 
    FileSaveAs 另存为 
    FileOpen 打开 
    FileClose 关闭 
    FilePrint 打印 
    FilePrintPreview 打印预览 
    ToolsCustomize 工具栏里面的自定义 
    ToolsOptions 工具选项 
    ToolsRevisions 突出显示修订 
    ToolsReviewRevisions 接受或拒绝修订 
    ToolsRevisionMarksAccept 接受修订 
    ToolsRevisionMarksReject 拒绝修订 
    ToolsRevisionMarksToggle 修订 
    ToolsMacro 宏 
    ToolsRecordMacroToggle 录制新宏 
    ViewSecurity 安全性 
    ViewVBCode 查看VB编辑器环境 
    FileTemplates 模板和可加载项 
    ToolsProtectUnprotectDocument 解除对文档的保护 
    InsertHyperlink 插入超级链接 
    EditHyperlink 编辑超级链接 
    DeleteHyperlink 删除超级链接 
    EditLinks 查看、删除链接 
    EditPasteAsHyperlink 粘贴超级链接 
    FormatStyle 样式 
    EditBookMark 书签 Oleexcel时一些用用的代码
    [email protected]
      

  12.   

    一、Delphi程序启动excel
    采用CreateOleObjects的方法来启动excel,调用VBA代码,具体实现过程为:
    首先使用GetActiveOleObject('excel.Application')判断当前内存中是否存在excel程序,如果存在,则直接连接,如果没有excel程序,则使用CreateOleObject('excel.Application')启动excel二、Delphi程序新建excel文稿
    格式:excelDocuments.Add(Template,NewTemplate,DocumentType,Visible)
    Template: 使用模板的名称,
    NewTemplate: 新建文档的类型,True表示为模板,False表示为文档
    DocumentType: 文档类型,默认为空白文档
    Visible: 打捞的窗口是否可见举例:Doc_Handle:=excel_Ole.Documents.Add(Template:='C:\Temlate.dot',NewTemplate:=False);三、Delphi程序打开excel文稿
    格式:excelDocuments.Open(FileName,ConfirmConversions,ReadOnly,PassexcelDocument,
    PassexcelTemplate,Revent,WritePassexcelDocument,WritePassexcelTemplate,
    Format,Encoding,Visible)FileName: 文档名(包含路径)
    Confirmconversions: 是否显示文件转换对话框
    ReadOnly: 是否以只读方式打开文档
    AddToRecentFiles: 是否将文件添加到"文件"菜单底部的最近使用文件列表中
    PassexcelDocument: 打开此文档时所需要的密码
    PassexcelTemplate: 打开此模板时所需要的密码
    Revert: 如果文档已经,是否重新打开文档
    WritePassexcelDocument: 保存对文档更改时所需要的密码
    WritePassexcelTemplate: 保存对模板进行更改时所需要的密码
    Format: 打开文档时所需使用的文件转换器
    Encoding: 所使用的文档代码页
    Visible: 打开文档的窗口是否可见举例:
    Doc_Handle:=excel_Ole.Documents.open(FileName:=Doc_File,ReadOnly:=False,
    AddToRecentFiles:=False);四、Delphi程序保存excel文稿
    格式:excelDocuments.SaveAs(FileName, FileFormat, LockComments, Passexcel,
    AddToRecentFiles, WritePassexcel, ReadOnlyRecommended, 
    EmbedTrueTypeFonts, SaveNativePictureFormat, SaveFormsData, 
    SaveAsAOCELetter)FileName: 文件名。默认为当前文件夹和文件名。
    FileFormat 文档保存的格式。
    LockComments 如果为 True,则此文档只允许进行批注。
    Passexcel 打开文档时的口令。
    AddToRecentFiles 如果为True,则将文档添至"文件"菜单中最近使用的文档列表中。
    WritePassexcel 保存对文档的修改所需的口令。
    ReadOnlyRecommended 如果为 True,在每次打开文档时,excel 将建议用户采用只读方式。
    EmbedTrueTypeFonts 如果为 True,则将文档与 TrueType 字体一起保存。
    SaveNativePictureFormat 如果为 True,则从其他系统平台(例如 Macintosh)导入的图形仅保存其 Windows 版本。
    SaveFormsData 如果为 True,则将窗体中用户输入的数据存为一条数据记录。
    SaveAsAOCELetter 如果文档包含一个附加,当此属性值为 True 时,将文档存为一篇 AOCE 信笺(同时保存邮件)。举例:
    excel_Ole.Documents.SaveAs(FileName:=Doc_File,FileFormat=wdFormatDocument,
    AddToRecentFiles=False);五、从数据库读取文件到本地硬盘和从本地硬盘读取文件到数据库在数据库上使用Image二进制字段保存,使用Stream流的方式。创建文件流:
    excel_FileStream:=TFileStream.Create(Target_Name,fmOpenWrite or fmCreate);
    excel_FileStream.Position:=0;保存到数据库的Image字段:
    TBlobField(AdoQuery1.FieldByName(Column_Name)).SaveToStream(excel_FileStream);从数据库读取文件到本地硬盘:
    TBlobField(ADOQuery1.FieldByName(Column_Name)).loadfromStream(excel_FileStream);释放文件流:
    excel_FileStream.Free;六、全局消息的定义
    因为excel和Delphi程序是两个软件,相互之间通讯比较麻烦,所以使用全局消息的方法进行。
    全局消息必须首先注册,Windows返回系统空闲的消息号,当注册的消息相同时,
    Windows系统返回同一个值,这样就保证了使用这个消息号在两个程序之间通讯。定义消息的办法:
    szMessageString: pchar = 'XIDIAN_11_Stone';
    FMyJoinMessage := RegisterWindowMessage(szMessageString);发送消息的方法:
    SendMessage(对方句柄,消息,消息附带短变量,消息附带长变量)七、Delphi程序接收消息的方法
    Delphi接收消息有两种,一是重载特定消息,二是重载WndProc函数,在里面选择相应消息进行处理。
    法一,每次只能处理一条消息,而法二能够同时处理多条消息。对于法二,声明如下:
    procedure WndProc(var Message: TMessage);override
    必须注意,使用时需要在处理完自己消息处理后继承WndProc(Message)函数,否则系统会崩溃!八、excel中Combo对话框的动态生成以及Change事件
    建立类模块Combohander,在内部定义事件
    Public WithEvents ComboBoxEvent As Office.CommandBarComboBox定义Combo控件产生事件的模块
    Dim ctlComboBoxHandler As New ComboBoxHandler产生Combo对话框
    Set Cbo_ChooseDoc = CommandBars("添加的菜单").Controls.Add(Type:=msoControlComboBox, Temporary:=True)进行文件句柄设置,以产生Combo_Change事件
    Set ctlComboBoxHandler.ComboBoxEvent = Cbo_ChooseDoc 产生事件后,在类模块Combohander内选择ComboBoxEvent的Change事件,即可书写事件代码
    Sub ComboBoxEvent_Change(ByVal Ctrl As Office.CommandBarComboBox)九、一些excel的事件
    VBA代码中处理的excel事件有:Document_Close
    Application事件中需要处理的有:DocumentBeforeClose,DocumentChange。Document_Close:事件在文档关闭时产生事件
    DocumentBeforeClose:在文档被关闭以前先于excel判断文档是否保存,给出相应提示并进行相应处理。
    DocumentChange:文档切换,在文档从自己修改的文稿和其他人修改的文稿之间切换产生事件,
    主要处理设置文档权限等。  
      

  13.   

    在网上下载个超级猛料看看阿,上面有的,我也是从哪个上面看得啊,,delphi 相关网站都有啊
      

  14.   

    非常感谢coolfilm(苏飞工作室) ,我这几天也在网上查了不少关于自动宏的资料,也是有一个担心,自动宏容易引发宏病毒的问题。你给我的资料我先好好消化再给你加分。万分感谢!!
    pwzhu666(暴龙) ,你好!!请问这些资料你在哪个网址下载。请提供给我,我一并送分。谢谢
      

  15.   

    另:coolfilm(苏飞工作室),请问你对使用自动宏中如何尽量避免病毒感染有什么心得体会吗?
      

  16.   

    笨,叫你的学生在做作业时,统一格式,比如,数据透视表名叫sheetX,这样你就可以直接找这个表(sheet)了,如果没找到,就是没有了!