vb程序调用excel数据文档格式.docx
- 文档编号:19943590
- 上传时间:2023-01-12
- 格式:DOCX
- 页数:20
- 大小:57.65KB
vb程序调用excel数据文档格式.docx
《vb程序调用excel数据文档格式.docx》由会员分享,可在线阅读,更多相关《vb程序调用excel数据文档格式.docx(20页珍藏版)》请在冰豆网上搜索。
DeclareFunctionSendMessageLib"
Alias"
SendMessageA"
_
(ByValhwndAslong,ByValwMsgAsLong,ByValwParamAsLong,lParam_
AsAny)As_Long
以上是公有变量和API函数应在模块中声明。
SubGetExcel()
DimMyXLAsObject'
用于存放MicrosoftExcel引用的变量。
DimExcelWasNotRunningAsBoolean'
用于最后释放的标记。
OnErrorResumeNext'
延迟错误捕获。
'
不带第一个参数调用Getobject函数将返回对该应用程序的实例的引用。
如果该应用程序不在运行,则会产生错误。
SetMyXL=GetObject(,"
Excel.Application"
)
IfErr.Number<
>
0ThenExcelWasNotRunning=True
Err.Clear'
如果发生错误则要清除Err对象。
检测MicrosoftExcel。
如果MicrosoftExcel在运行,则将其加入运行对象表。
DetectExcel'
该过程检测并登记正在运行的Excel
设置其Application属性,显示MicrosoftExcel。
然后使用MyXL对象引用的Windows集合,显示包含该文件的实际窗口。
MyXL.Application.Visible=True
MyXL.Parent.Windows
(1).Visible=True
如果在启动时,MicrosoftExcel的这份副本不在运行中,
则使用Application属性的Quit方法来关闭它。
注意,当试图退出MicrosoftExcel时,
标题栏会闪烁,并显示一条消息询问是否保存所加载的文件。
IfExcelWasNotRunning=TrueThen
MyXL.Application.Quit
EndIf
SetMyXL=Nothing'
释放对该应用程序和电子数据表的引用。
EndSub
该过程检测并登记正在运行的Excel。
SubDetectExcel()
ConstWM_USER=1024
DimhwndAsLong
'
如果Excel在运行,则该API调用将返回其句柄。
hwnd=FindWindow("
XLMAIN"
0)
Ifhwnd=0Then'
0表示没有Excel在运行。
ExitSub
Else
Excel在运行,因此可以使用SendMessageAPI'
函数将其放入运行对象表。
SendMessagehwnd,WM_USER+18,0,0
有了Application对象,就可以非常方便地访问Excel应用程序中的其它对象,以及这此对象的属性和方法。
2.2workbooks对象的使用
dimxlbookasobject‘定义一个指向工作簿变量
setxlbook=xlapp.application.workbooks.add
使用ADD方法新建一个空白的工作簿。
2.3worksheets对象的使用
dimxlsheetasobject‘定义一个指向工作表的变量
setxlsheet=xlapp.application.workshets.add
或者:
setxlsheet=xlapp.application.worksheet
(1)‘指向当前工作簿的第一页
2.4Cells和Range对象的应用
引用一个工作表(xlsheet)中的某个单位格用以下代码:
xlsheet.cells(I,j)=100‘表示在第I行第J列中写入100这个数。
引用工作表中的多个单位格用以下代码:
Withxlsheet'
设置边框为是实际上线
.Range(.Cells(7,1),.Cells(28,29)).Borders.LineStyle=xlContinuous
EndWith
3应用实例
该实例给出怎样运行Excel创建复杂表格以及向表格填充数据的完整过程。
在开始应用程序前,我们要做的准备工作是建立一个我们所需格式的Excel模板。
模板的作用相信大家都不会陌生。
我所做的模板如下(模板文件取名为“土工试验成果表”):
模板可以存在指定的文件夹里,也可以在于Excel存放模板的文件夹里。
打开VB编程环境,选择新建一标准工程。
要想在VB中很好地调用Excel,首先必须打开VB编程环境“工程”菜单中的“引用”项目,并选取项目中的“MicrosoftExcel8.0objectlibrary项。
然后在窗体中加入一命令按钮,其caption属性为:
Excel输出。
即command1.caption=Excel输出。
以下是代码,其中模块中的代码和上面介绍的application使用代码是一样的,不再列出。
PrivateSubCommand1_Click()
Dimi,jAsInteger
CallGetExcel
Setxlapp=GetObject("
土工试验成果表.XLS"
)'
打开模扳文件
xlapp.Parent.Windows
(1).Visible=True'
使父窗体可见
Setxlsheet=xlapp.Application.Worksheets
(1)'
当前工作簿的第一页
Fori=7To28‘这段代码是将整数1到29写入单位格中,实际应用时可
Forj=1To29‘读一数据文件并按要求写入表格中
xlsheet.Cells(i,j)=j'
当前工作簿第一页的第I行第J列
Nextj
Nexti
设置边框为是实线
.Range(.Cells(7,1),.Cells(28,29)).Borders.LineStyle=xlContinuous
EndWith
xlsheet.SaveAs"
d:
\temp\w2.xls"
‘按指定文件名存盘
引用当前工作簿的第二页
Setxlsheet=xlapp.Application.Worksheets
(2)
xlsheet.Cells(7,2)=789‘在第二页的第7行第2列写入789
Setxlbook=xlapp.Application.Workbooks.Add'
新建一空白工作簿
参照上述代码,就可以随心所欲地发挥你的编程艺术了。
其实你还可以让Excel在后台运行,甚至于直接在打印机上输出结果,认人感觉不到Excel在运行,是不是很方便?
以上只是本人的一点心得,若有错误,不吝赐教。
所以我写这一篇贴子,供大家参考,希望能给大家一定的帮助。
SetxlApp=CreateObject("
创建EXCEL对象
SetxlBook=xlApp.Workbooks.Open(App.Path&
\文件名.xls"
打开已经存在的EXCEL工件簿文件
xlApp.Visible=True'
设置EXCEL对象可见(或不可见)
SetxlSheet=xlBook.Worksheets("
sheel1"
设置活动工作表,sheet1表示表名,可以使用字符型变量代替。
xlSheet.Activate'
激活工作表,让它处于前台活动中。
xlBook.RunAutoMacros(xlAutoOpen)'
运行自动开启宏Macro1(),在EXCEL中加入以下宏
Subauto_open()'
这是VBA中的自动打开时运行的宏
您要宏自动运行的程序,比如可以call其它的宏,这样VB在打开EXCEL时,使用上面的语句就可以先运行这个宏
xlSheet.Cells.Item(行数,列数)=值
给EXCEL对象中的表的单元格附值。
xlSheet.Rows("
7:
7"
).Select
选定EXCEL表的第7行
xlApp.Selection.Deleteshift:
=xlUp'
删除选定的行
xlSheet.Rows(7).Insert'
在第7行处插入一行
ActiveSheet.PageSetup.CenterHeader="
页眉内容"
给页眉附值
xlSheet.Range("
f7:
h7"
选定f7:
h7之间的单元格,下面的程序是把它们
合并。
Application.CutCopyMode=False
WithxlApp.Selection
.HorizontalAlignment=xlGeneral
.VerticalAlignment=xlCenter
.WrapText=False
.Orientation=0
.AddIndent=False
.IndentLevel=0
.ShrinkToFit=False
.ReadingOrder=xlContext
.MergeCells=True
在VB应用程序中调用Excel2000
发表日期:
2006-08-23
作者:
[转贴]出处:
一、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应用程序的编程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:
求值数学表达式:
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("
WithVBExcel
.Workbooks.Add
WithActiveWorkbook
.SaveAs"
C:
\Temp\OUTPUT.XLS"
.Close
EndWith
.Quit
2、使用工作表
Sheets集合表示工作簿中所有的工作表。
可以通过Sheets集合来访问、激活、增加、更名和删除工作表。
一个Worksheet对象代表一个工作表。
常用的属性、方法有:
Worksheets属性返回Sheets集合。
Name属性工作表更名。
Add方法创建新工作表并将其添加到工作簿中。
Select方法选择工作表。
Copy方法复制工作表。
Move方法将指定工作表移到工作簿的另一位置。
Delete方法删除指定工作表。
PrintOut方法打印工作表。
示例3:
将C盘工作簿中的工作表复制到A盘工作簿中:
SetVBExcel=CreateObject("
.Workbooks.Open"
\Temp\OUTPUT.XLS"
.Workbooks.Open"
A:
\OUTPUT1.XLS"
.Workbooks("
OUTPUT.XLS"
).Sheets("
Sales"
).Copy
OUTPUT1.XLS)
OUTPUT1.XLS"
).Save
).Close
OUTPUTI.XLS"
.Quit
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,x1XY
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- vb 程序 调用 excel 数据