在VB应用程序中调用Excel2000
Visual Basic简称(VB)是设计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对象常用的属性、方法
属性、方法 | 方法 |
Visible属性 | 取True或False,表明Excel应用程序是否可见。 |
Left,Top属性 | Excel窗口的位置; |
Height, Width属性 | Excel窗口的大小; |
WindowState属性 | 指定窗口的状态,取:XIMaximized(最大化)X1 Minimized(最小化)x1 Normal(缺省)。 |
Quit方法 | 退出Microsoft Excel; |
Calculate方法 | 重新计算所有打开的工作簿、工作表或单元格。 |
Evaluate方法 | 求值数学表达式并返回结果。 |
示例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对象。
常用的方法有:
属性、方法 | 意义 |
Add方法 | 创建新的空白工作簿,并将其添加到集合中。 |
Open方法 | 打开工作簿。 |
Activate方法 | 激活工作簿,使指定工作簿变为活动工作簿,以便作为Active Workbook对象使用。 |
Save方法 | 按当前路径和名称保存现有工作簿(如是首次保存,则将其保存到缺省名称中,如BOOK1.XLS)。 |
SaveAs方法 | 首次保存工作簿或用另一名称保存工作簿。 |
Close方法 | 关闭工作簿。 |
PrintOut方法 |
打印工作簿,语法为:
PrintOut (from, To, Copies, Preview, Printer, ToFile, Collate) 可选参数: From:打印的起始页号。如省略将从起始位置开始打印。 |
下面语句将活动工作簿的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对象代表一个工作表。
常用的属性、方法有:
属性、方法 | 意义 |
Worksheets属性 | 返回Sheets集合。 |
Name属性 | 工作表更名。 |
Add方法 | 创建新工作表并将其添加到工作簿中。 |
Select方法 | 选择工作表。 |
Copy方法 | 复制工作表。 |
Move方法 | 将指定工作表移到工作簿的另一位置。 |
Delete方法 | 删除指定工作表。 |
PrintOut方法 | 打印工作表。 |
示例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对象代表工作表的某一单元格、某一行、某一列、某一选定区域或者某一三维区域。
常用的属性、方法有:
属性、方法 | 意义 |
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、x13 DSurface、xlDoughnut或xlDefaultAutoFormat。 Format:内置自动套用格式的编号。如省略,将选择默认值。 P1otBy:指定系列中的数据是来自行(xlRows)还是列(xlColumns)。 CategoryLabels:表示包含分类标志的源区域内行数或列数的整数。 SeriesLabels:表示包含系列标志的源区域内行数或列数的整数。 HasLegend:若指定True,则图表将具有图例。 Title:图表标题文字。 CategoryTitle:分类轴标题文字。 ValueTitle:数值轴标题文字。 ExtraTitle:三维图表的系列轴标题,或二维图表的第二数值轴标题。 |
可组合使用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应用程序中调用,其原理和步骤完全相同,只是其对象模型有所不同而已。
转载于:https://www.cnblogs.com/Nina-piaoye/archive/2008/12/26/1363064.html
在VB应用程序中调用Excel2000相关推荐
- VB应用程序中实现查找和替换功能
一?前言 尽管Visual Basic并不是我最喜欢的开发工具,但我喜欢它简单而又丰富的库集.每当开发一个需要处理大量文本数据的应用程序时,需要具有拼写错误纠正功能,例如,微软的Word程序,当运行& ...
- [翻译]Kean' Blog 在一个.NET应用程序中调用AutoCAD
程序员通常要么整合功能到AutoCAD(利用其Plug-in结构,以增加命令,用户界面,对象等),或者调用它自动完成任务.显然,这两者之间的界限已经比较模糊,但是今天我们重点介绍第二类. 用于帮助理解 ...
- 本地方法(JNI)——从java 程序中调用C函数
[0]README 1) 本文部分文字描述 转自 core java volume 2 , 旨在理解 本地方法--从java 程序中调用C函数 的基础知识 : 2) for source code, ...
- Linux jsp php集成环境,ImageMagick在程序中调用(linux环境,jsp,php)
最近发现图片格式为cmyk时,图片上传浏览器不能正常显示,图片缩放会变成黑屏, 后来通过google发现imagemagick的功能很强大,安装可以采用两种方法,1)直接与php编译安装,在程序中调用 ...
- SQL Server 2005 - 如何在预存程序中调用另外一个预存程序
要在一个预存程序中调用另外一个预存程序,可以使用下列两种方式之一进行调用: <?xml:namespace prefix = o /> EXECUTE <欲执行之预存程序的名称&g ...
- 在Delphi程序中调用控制面板设置功能
====================================================== 注:本文源代码点此下载 ================================= ...
- 安卓程序中调用 linux 命令
博客: 安卓之家 微博: 追风917 CSDN: 蒋朋的家 简书: 追风917 在研究串口 jni 开发的时候,遇到了这样一段代码: Process su;su = Runtime.getRuntim ...
- iOS程序中调用系统自带应用(短信,邮件,浏览器,地图,appstore,拨打电话,iTunes,iBooks )...
在网上找到了下在记录下来以后方便用 在程序中调用系统自带的应用,比如我进入程序的时候,希望直接调用safar来打开一个网页,下面是一个简单的使用: 查看更多iPhone应用程序的调用和第三方应用程序的 ...
- python调用安卓相机_Android在应用程序中调用相机程序
有时,需要在应用程序中调用其他Android上已经安装完好的应用程序, 以下是一个调用相机(com.android.camera)的demo程序: PackageInfo pi = null; try ...
最新文章
- GHOST系统封装详细图文教程
- 多线程:同步和异步的优缺点比较
- hdu 5730 Shell Necklace——多项式求逆+拆系数FFT
- oracle复合索引介绍(多字段索引)
- 制作模块-安装模块压缩包
- docker选择安装位置_监控摄像机的安装位置选择和焦距选择
- MyBatis的resultType和resultMap的区别
- ldconfig和ldd用法
- Nginx学习之十一-Nginx启动框架处理流程
- 10.2829(NOIP模拟修正总结)
- 使用Python处理声音文件(二):音量降低1/2
- 在Android中调用KSOAP2库访问webservice服务出现的服务端传入参数为null的问题解决
- 数据库dba_DBA延伸数据库指南
- 「代码随想录」关于多重背包,你该了解这些!
- 信息安全之程序实现简单替换加密,并用字母频率统计进行破解
- 强大的 actuator 服务监控与管理
- 【经验】秀米排版指南|特殊布局(如文字环绕图片等无法使用秀米基本布局组合出来的布局)
- 三角(Triangle)
- 黑苹果安装资源已过期 10.13,10.12
- Prometheus 监控基础
热门文章
- React开发(203):react代码分割之React.lazy
- Taro+react开发(36)每一个节点要一个view包裹
- react(83)--filter
- 前端学习(3194):虚拟dom的创建方式1的jsx
- [html] 说说base标签有什么作用?
- [vue] 分析下vue项目本地开发完成后部署到服务器后报404是什么原因呢?
- [vue] vue组件之间的通信都有哪些?
- 前端学习(2868):vue3数据劫持解析3
- 工作71:nexttick使用
- 前端学习(2483):修改文章