在VB应用程序中调用Excel2000

  Visual Basic简称(是设计Windows应用程序强有力的开发工具,"全球绝大多数Windows应用程序都是用VB开发的"; Excel是目前使用最广泛的办公应用软件之一,它具有强大的数学分析与计算功能,包括很多VB没有的求值数学表达式的函数和方法。由于Excel的应用程序对象是外部可创建的对象,所以能从VB应用程序内部来程序化操纵Excel。本文结合自己的实践和体会,谈谈如何在VB6.0应用程序中调用Exce12000,供大家参考。

  一、Excel对象模型

  为了在VB应用程序中调用Excel,必须要了解Excel对象模型。Excel对象模型描述了Excel的理论结构,所提供的对象很多,其中最重要的对象,即涉及VB调用Excel最可能用到的对象有:

  

  二、调用Excel

  在VB应用程序中调用Excel,实质是将Excel作为一个外部对象来引用,由Excel对象模型提供能从VB应用程序内部来程序化操纵的对象以及相关的属性、方法和事件。

  1、在VB工程中添加对Excel类型库的引用

  为了能从VB应用程序中访问Excel丰富的内部资源,使Excel应用程序运行得更快,需要在VB工程中添加对Excel类型库的引用。具体步骤如下:

  a)从VB5"工程"菜单中选择"引用";

  b) 在"引用"对话框中选择Excel类型库:"Microsoft Excel9.0 Object Library";

  c)单击左边小方框,使之出现"√"符号;

  d)按"确定"退出。

  注:要想在VB应用程序中调用Excel,你的计算机系统中必须安装Excel。

  2、引用Application对象

  Application对象是Excel对象模型的顶层,表示整个Excel应用程序。在VB应用程序中调用Excel,就是使用Application对象的属性、方法和事件。为此,首先要声明对象变量:

  
Dim VBExcel As Object

  或直接声明为Excel对象:

  
Dim VBExcel As Excel.Application

  在声明对象变量之后,可用CreateObject函数或GetObject函数给变量赋值新的或已存在的Application对象引用。

  a)用CreateObject函数生成新的对象引用:

  
Set VBExcel=CreateObject ("Excel.Application")

  字符串"Excel.Application"是提供Excel应用程序的编程ID,这个变量引用Excel应用程序本身。

  b)用GetO场ect函数打开已存在的对象引用:

  
Set AppExcel=GetObject("SAMP.XLS")

  上面语句打开文件SAMP.XLS。

  3、Application对象常用的属性、方法

  

  示例1:求值数学表达式:

  
Dim VBExcel As Object
  Set VBExcel=CreateObject ("Excel.Application")
  X=VBExcel. Evaluate ("3+5*(cos (1/log (99. 9)))")

  三、使用Excel应用程序

  如前所述,在VB应用程序中调用Excel应用程序,就是使用Application对象的属性、方法和事件。下面分类给出其中常用的属性和方法。

  1、使用工作薄

  Workbook对象代表Excel应用程序中当前打开的一个工作簿,包含在Workbooks集合中。可以通过Workbooks集合或表示当前活动工作簿的Active Workbook对象访问Workbook对象。

  常用的方法有:

  

  下面语句将活动工作簿的2到5页打印3份:

  
ActiveWorkbook.PrintOut From:=2 To 5 Copies:=3

  示例2:生成、保存、关闭工作簿

  
Dim VBExcel As Excel.Application
  Set VBExcel== CreateObject("Excel.Application")
  With VBExcel
    .Workbooks.Add
    With ActiveWorkbook
      .Save As"C: \Temp \OUTPUT.XLS"
      .Close
    End With
    .Quit
  End With

  2、使用工作表

  Sheets集合表示工作簿中所有的工作表。可以通过Sheets集合来访问、激活、增加、更名和删除工作表。一个Worksheet对象代表一个工作表。

  常用的属性、方法有:

  

  示例3:将C盘工作簿中的工作表复制到A盘工作簿中:

  
Dim VBExcel As Excel.Application
  Set VBExcel=CreateObject("Excel.Application")
  With VBExcel
   .Workbooks.Open "C:\Temp\OUTPUT.XLS"
   .Workbooks.Open"A:\OUTPUT1.XLS"
   .Workbooks("OUTPUT.XLS").Sheets ("Sales").Copy
   .Workbooks("OUTPUT1.XLS)
   .Workbooks("OUTPUT1.XLS").Save
   .Workbooks("OUTPUT.XLS").Close
   .Workbooks("OUTPUTI.XLS").Close
   .Quit
  End With

  3、使用单元范围

  Range对象代表工作表的某一单元格、某一行、某一列、某一选定区域或者某一三维区域。

  常用的属性、方法有:

  

  4、使用图表

  Chart对象代表工作簿中的图表。该图表既可为嵌人式图表(包含于ChartObject对象中)也可为分立的图表工作表。

  常用方法有:

  

  可组合使用Add方法和ChartWizard方法,以创建包含工作表中数据的图表工作表。下例基于工作表"Sheetl"中单元格区域"A1:A20"中的数据生成新的折线图并打印。

  
With Charts.Add
   .ChartWizard source:=Worksheets ("sheet1").Range ("a1:a20"),gallery:=xlLine, title:="折线图表"
   .Printout
  End With

  5、使用Excel工作表函数

  在VB语句中可使用大部分的Excel工作表函数,可通过WorksheetFunction对象调用Excel工作表函数。下面的Sub过程用Min工作表函数求出指定区域中单元格的最小值,并通过消息框显示结果值。

  
Sub UseFunction()
  Dim myRange As Range
  Set myRange=Worksheets ("Sheet1").Range("B2:F10")
  answer=Application.WorksheetFunction.Min(myRange)
  MsgBox answer
  End Sub

  如果使用以区域引用为参数的工作表函数,必须指定一个Range对象。如可用Match工作表函数对A1:A10区域的所有单元格进行搜索。

  
Sub FindFirst()
  my Var=Application.WorksheetFunction.Match (9, Worksheets( 1).Range("A1:A10"),0)
  MsgBox myVar
  End Sub

  要在单元格中插人工作表函数,可将该函数指定为对应于Range对象的Formula属性值。在以下示例中,将当前工作簿Sheetl内A1:B3区域的Formula属性指定为RAND工作表函数(此函数产生二个随机数)。

  
Sub InsertFormula()
  Worksheets ("Sheet1" ).Range("A1:B3").Formula="RAND()"
  End Sub

  以上简要介绍了Excel对象模型中部分对象及其属性和方法,更详细的信息可参阅Excel 2000帮助中的"Microsoft Excel Visual Basic参考"一节的内容。实际上,Microsoft Office家族的Word,PowerPoint, Access和Project等应用程序都可以在VB应用程序中调用,其原理和步骤完全相同,只是其对象模型有所不同而已。

评论: 0 | 引用: 0 | 查看次数: 5318
发表评论
登录后再发表评论!