在VB应用程序中调用Excel2000
时间:2009-6-2 10:27:48 作者: 来源:
 
一、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类型库:"microsoftexcel9.0objectlibrary";

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

  d)按“确定”退出。

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

  2、引用application对象

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

  dimvbexcelasobject

  或直接声明为excel对象:  

  dimvbexcelasexcel.application

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

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

  setvbexcel=createobject("excel.application")

  字符串“excel.application”是提供excel应用程序的编程id,这个变量引用excel应用程序本身。

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

  setappexcel=getobject("samp.xls")

  上面语句打开文件samp.xls。

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

  属性、方法方法

  visible属性取true或false,表明excel应用程序是否可见。

  left,top属性excel窗口的位置;

  height,width属性excel窗口的大小;

  windowstate属性指定窗口的状态,取:ximaximized(最大化)x1minimized(最小化)x1normal(缺省)。

  quit方法退出microsoftexcel;

  calculate方法重新计算所有打开的工作簿、工作表或单元格。

  evaluate方法求值数学表达式并返回结果。

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

  dimvbexcelasobject

  setvbexcel=createobject("excel.application")

  x=vbexcel.evaluate("3 5*(cos(1/log(99.9)))")
  三、使用excel应用程序

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

  1、使用工作薄

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

  常用的方法有:  

  属性、方法意义

  add方法创建新的空白工作簿,并将其添加到集合中。

  open方法打开工作簿。

  activate方法激活工作簿,使指定工作簿变为活动工作簿,以便作为activeworkbook对象使用。

  save方法按当前路径和名称保存现有工作簿(如是首次保存,则将其保存到缺省名称中,如book1.xls)。

  saveas方法首次保存工作簿或用另一名称保存工作簿。

  close方法关闭工作簿。

  printout方法打印工作簿,语法为:  

  printout(from,to,copies,preview,printer,tofile,collate)

  可选参数:  

   from:打印的起始页号。如省略将从起始位置开始打印。

   to:打印的终止页号。如省略将打印至最后一页。

   copies:要打印的份数。如省略将只打印一份。

   preview:如果为true则excel打印指定对象之前进行打印预览。如果为false,或省略则立即打印该对象。

   printer:设置活动打印机的名称。

   tofile:如果为true则打印输出到文件。

   collate:如果为true则逐份打印每份副本。

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

  activeworkbook.printoutfrom:=2to5copies:=3

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

  dimvbexcelasexcel.application

  setvbexcel==createobject("excel.application")

  withvbexcel

  .workbooks.add

  withactiveworkbook

  .saveas"c:\temp\output.xls"

  .close

  endwith

  .quit

  endwith

  2、使用工作表

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

  常用的属性、方法有:  

  属性、方法意义

  worksheets属性返回sheets集合。

  name属性工作表更名。

  add方法创建新工作表并将其添加到工作簿中。

  select方法选择工作表。

  copy方法复制工作表。

  move方法将指定工作表移到工作簿的另一位置。

  delete方法删除指定工作表。

  printout方法打印工作表。

  示例3:将c盘工作簿中的工作表复制到a盘工作簿中:  

  dimvbexcelasexcel.application

  setvbexcel=createobject("excel.application")

  withvbexcel

   .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

  endwith

  3、使用单元范围

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

  常用的属性、方法有:  

  属性、方法意义

  range属性range(arg)其中arg为a1--样式符号,表示单个单元格或单元格区域。

  cells属性cells(row,col)(其中row为行号,col为列号)表示单个单元格。

  columnwidth属性指定区域中所有列的列宽。

  rowl3eight属性指定区域中所有行的行宽。

  value属性指定区域中所有单元格的值(缺省属性)。

  formula属性指定单元格的公式,由a1--样式引用。

  select方法选择范围。

  copy方法将范围的内容复制到剪贴板。

  c1earcontents方法清除范围的内容。

  delete方法删除指定单元范围。


  4、使用图表

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

  常用方法有:  

  方法意义  

  add方法新建图表工作表。返回chart对象。

  prineout方法打印图表。

  chartwizard方法修改给定图表的属性,其语法为:   

  chartwizard(source,gallery,format,p1otby,categorylabels,

  serieslabels,haslegend,title,categorytitle,valuetitle,extratitle)

  其中:

  source:包含新图表的源数据的区域。如省略,将修改活动图表工作表或活动工作表中处于选定状态的嵌人式图表。

  gallery:图表类型。其值可为下列常量之一:xlarea,x1bar,xlcolumn,xlline,x1pie,xlradar,x1xyscatter,xlcombination,x13darea,x13dbar、x13dcolumn,x13dline,x13dpie、x13dsurface、xldoughnut或xldefaultautoformat。

  format:内置自动套用格式的编号。如省略,将选择默认值。

  p1otby:指定系列中的数据是来自行(xlrows)还是列(xlcolumns)。

  categorylabels:表示包含分类标志的源区域内行数或列数的整数。

  serieslabels:表示包含系列标志的源区域内行数或列数的整数。

  haslegend:若指定true,则图表将具有图例。

  title:图表标题文字。

  categorytitle:分类轴标题文字。

  valuetitle:数值轴标题文字。

  extratitle:三维图表的系列轴标题,或二维图表的第二数值轴标题。

  可组合使用add方法和chartwizard方法,以创建包含工作表中数据的图表工作表。下例基于工作表“sheetl”中单元格区域“a1:a20”中的数据生成新的折线图并打印。  

  withcharts.add

   .chartwizardsource:=worksheets("sheet1").range("a1:a20"),gallery:=xlline,title:=“折线图表”

   .printout

  endwith  

  5、使用excel工作表函数

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

  subusefunction()

  dimmyrangeasrange

  setmyrange=worksheets("sheet1").range("b2:f10")

  answer=application.worksheetfunction.min(myrange)

  msgboxanswer

  endsub

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

  subfindfirst()

  myvar=application.worksheetfunction.match(9,worksheets(1).range("a1:a10"),0)

  msgboxmyvar

  endsub

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

  subinsertformula()

  worksheets("sheet1").range("a1:b3").formula="rand()"

  endsub

  以上简要介绍了excel对象模型中部分对象及其属性和方法,更详细的信息可参阅excel2000帮助中的“microsoftexcelvisualbasic参考”一节的内容。实际上,microsoftoffice家族的word,powerpoint,access和project等应用程序都可以在vb应用程序中调用,其原理和步骤完全相同,只是其对象模型有所不同而已。

->


上一篇:
下一篇:
 
网页模板 网站模板 网站建设 网页设计 网页设计师兼职 自助建站 ...
网站魔坊,网页模板,网站模板,免费网页模板,在线模板设计,免费建站,门户网站搭建,建站,企业网站,奇思网络,奇思,智能建站,自助建站,拖动建站,网站建设,网页设计,在线设计模板
www.wzmof.com/ 47K 2009-5-21
 
商巢...
商巢是一个真实的商业交友社区、为用户提供交友、贸易、社区、建站等服务;临渊慕鱼,不如退而结网!商巢结网行动
www.ncooo.com/ 47K 2009-5-21
 
商巢创业 门户创业 商人网络家园 魔坊建站 商业交友
商巢下的门户,门户又一独立实体与商巢合作,由商巢负责技术的更新以及硬件的支持,门户负责自己领域的市场推广以及相应的售后服务即可。 打破以往门户需要源源不断的技术、硬件投入模式,盈利模式清晰 行业门户以及门户下企业网站由网站魔坊...
mhcy.ncooo.com/ 36K 2009-5-14
 
奇思网络技术 网站建设 深圳网站建设
中小外贸企业做电子商务,需要从两点技术突围 08-01 企业网站建设 提供网站策划、网站建设、数据库开发至网络营销全套解决方案。能针对客户所处行业,结合营销特征量身订做高质量网站建设方案。 网站推广 怎样使网站的投资得到回报?这需要经验...
www.qsnet.com.cn/ 48K 2009-4-2
 
深圳艺术网
深圳艺术网,中国艺术网,中国当代艺术网,广东当代艺术网,广东艺术网,南方当代艺术网,深圳美术网,深港美术网,深港艺术网,深港当代艺术网,杜应红,深圳当代艺术创作库,深圳创库,深圳美术,深圳艺术,深圳收藏,深圳艺术收藏,深圳音乐网,深圳舞蹈...
www.szarts.cn/ 119K 2009-6-9
 
网页设计也通过人脉赚钱-技术传播
 
网页设计114 -打造中国网页设计、网站建设技术信息学习、交流、互动平台
                         打造网页设计师兼职创业平台中心