为了在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应用程序中调用,其原理和步骤完全相同,只是其对象模型有所不同而已。
->