VB打开Excel文件

前端之家收集整理的这篇文章主要介绍了VB打开Excel文件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
(1)vb打开Excel
用EXCEL对象读取EXCEL文件中数据.然后通过ADODB连接sql进和导入 @H_301_10@ 下面是EXCEL对象的详解

1 前言

做为一种简捷、系统的 Windows应用程序开发工具,VB具有强大的数据处理功能,提供了多种数据访问方法,可以方便地存取Microsoft sql Server、Oracle、XBase等多种数据库,被广泛应用于建立各种信息管理系统。但是,VB缺乏足够的、符合中文习惯的数据表格输出功能,虽然使用Crystal Report控件及 Crystal Reports程序可以输出报表,但操作起来比较麻烦,中文处理能力也不理想。Excel在表格方面有着强大的功能,我们可以用VB编写直接控制Excel操作的程序,方法是用VB的OLE自动化技术获取Excel的控制句柄,从而直接控制Excel的一系列操作。本文结合自己的实践和体会,谈谈如何在VB6.0应用程序中调用Exce12000,供大家参考。

2 Excel对象模型

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

3 调用Excel

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

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

为了能从VB应用程序中访问Excel丰富的内部资源,使Excel应用程序运行得更快,需要在VB工程中添加对Excel类型库的引用。具体步骤如下: @H_301_10@ 1) 在VB应用程序中调用Excel,你的计算机系统中必须安装Excel。从VB5“工程”菜单中选择“引用”; @H_301_10@ 2) 在“引用”对话框中选择Excel类型库:"Microsoft Excel9.0 Object Library";@H_301_10@ 3) 单击左边小方框,使之出现“√”符号; @H_301_10@ 4) 按“确定”退出

3.2 引用Application对象

Application对象是Excel对象模型的顶层,表示整个Excel应用程序。在VB应用程序中调用Excel,就是使用Application对象的属性方法和事件。为此,首先要声明对象变量:@H_301_10@ Dim VBExcel As Object@H_301_10@ 或直接声明为Excel对象: @H_301_10@ Dim VBExcel As Excel.Application @H_301_10@ 在声明对象变量之后,可用CreateObject函数或GetObject函数给变量赋值新的或已存在的Application对象引用。

1)用CreateObject函数生成新的对象引用: @H_301_10@ Set VBExcel=CreateObject ("Excel.Application") @H_301_10@ 字符串“Excel.Application”是提供Excel应用程序的编程ID,这个变量引用Excel应用程序本身。

2)用GetO场ect函数打开已存在的对象引用: @H_301_10@ Set AppExcel=GetObject("Temp.XLS") @H_301_10@ 上面语句打开文件Temp.XLS。

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

Visible属性取True或False,表明Excel应用程序是否可见。 @H_301_10@ Left,Top属性, Excel窗口的位置;@H_301_10@ Height,Width属,性Excel窗口的大小; @H_301_10@ WindowState属性,指定窗口的状态; @H_301_10@ Quit方法退出Microsoft Excel; @H_301_10@ Calculate方法, 重新计算所有打开的工作簿、工作表或单元格。 @H_301_10@ Evaluate方法, 求值数学表达式并返回结果。

3.3 使用Excel应用程序

下面分类给出其中常用的属性方法。 @H_301_10@ 1)使用工作薄@H_301_10@ Workbook对象代表Excel应用程序中当前打开的一个工作簿,包含在Workbooks集合中。可以通过Workbooks集合或表示当前活动工作簿的Active Workbook对象访问Workbook对象。

常用的方法有: @H_301_10@ Add方法: 创建新的空白工作簿,并将其添加到集合中。 @H_301_10@ Open方法: 打开工作簿。 @H_301_10@ Activate方法:激活工作簿,使指定工作簿变为活动工作簿,以便作为Active Workbook对象使用。 @H_301_10@ Save方法: 按当前路径和名称保存现有工作簿(如是首次保存,则将其保存到缺省名称中,如BOOK1.XLS)。 @H_301_10@ SaveAs方法: 首次保存工作簿或用另一名称保存工作簿。 @H_301_10@ Close方法: 关闭工作簿。 @H_301_10@ PrintOut方法:打印工作簿,语法为: @H_301_10@ PrintOut (from,To,Copies,Preview,Printer,ToFile,Collate) @H_301_10@ 可选参数: @H_301_10@ From:打印的起始页号,如省略将从起始位置开始打印。 @H_301_10@ To:打印的终止页号,如省略将打印至最后一页。 @H_301_10@ Copies:要打印的份数,如省略将只打印一份。 @H_301_10@ Preview:如果为True则Excel打印指定对象之前进行打印预览。如果为False或省略则立即打印该对象。 @H_301_10@ Printer:设置活动打印机的名称。 @H_301_10@ ToFile:如果为True则打印输出文件。 @H_301_10@ Collate:如果为True则逐份打印每份副本。 @H_301_10@ 下面语句将活动工作簿的2到5页打印3份: @H_301_10@ ActiveWorkbook.PrintOut From:=2 To 5 Copies:=3 @H_301_10@ @H_301_10@ 2)使用工作表 @H_301_10@ Sheets集合表示工作簿中所有的工作表。可以通过Sheets集合来访问、激活、增加、更名和删除工作表。一个Worksheet对象代表一个工作表。 @H_301_10@ @H_301_10@ 常用的属性方法有: @H_301_10@ Worksheets属性:返回Sheets集合。 @H_301_10@ Name属性: 工作表更名。 @H_301_10@ Add方法: 创建新工作表并将其添加到工作簿中。 @H_301_10@ Select方法: 选择工作表。 @H_301_10@ Copy方法: 复制工作表。 @H_301_10@ Move方法: 将指定工作表移到工作簿的另一位置。 @H_301_10@ Delete方法: 删除指定工作表。 @H_301_10@ PrintOut方法: 打印工作表。 @H_301_10@ @H_301_10@ 示例:将C盘工作簿中的工作表复制到A盘工作簿中: @H_301_10@ Dim VBExcel As Excel.Application @H_301_10@ Set VBExcel=CreateObject("Excel.Application") @H_301_10@ With VBExcel @H_301_10@ Workbooks.Open "C:\Temp\Ex1.XLS" @H_301_10@ Workbooks.Open"A:\Ex2.XLS" @H_301_10@ Workbooks("Ex1.XLS").Sheets ("Sales").Copy @H_301_10@ Workbooks("Ex2.XLS") @H_301_10@ Workbooks("Ex2.XLS").Save @H_301_10@ Workbooks("Ex1.XLS").Close @H_301_10@ Workbooks("Ex2.XLS").Close @H_301_10@ Quit @H_301_10@ End With @H_301_10@ @H_301_10@ 3)使用单元范围 @H_301_10@ Range对象, 代表工作表的某一单元格、某一行、某一列、某一选定区域或者某一三维区域。 @H_301_10@ 常用的属性方法有: @H_301_10@ Range属性: Range (arg)其中arg为A1样式符号,表示单个单元格或单元格区域。 @H_301_10@ Cells属性: Cells (row,col )(其中row为行号,col为列号)表示单个单元格。 @H_301_10@ ColumnWidth属性: 指定区域中所有列的列宽。 @H_301_10@ Rowl3eight属性: 指定区域中所有行的行宽。 @H_301_10@ Value属性: 指定区域中所有单元格的值(缺省属性)。 @H_301_10@ Formula属性: 指定单元格的公式,由A1--样式引用。 @H_301_10@ Select方法: 选择范围。 @H_301_10@ Copy方法: 将范围的内容复制到剪贴板。 @H_301_10@ C1earContents方法: 清除范围的内容。 @H_301_10@ Delete方法: 删除指定单元范围。 @H_301_10@ @H_301_10@ 4)使用图表 @H_301_10@ Chart对象, 代表工作簿中的图表。该图表既可为嵌人式图表(包含于ChartObject对象中)也可为分立的图表工作表。 @H_301_10@ 常用方法有: @H_301_10@ Add方法: 新建图表工作表,返回Chart对象。 @H_301_10@ PrineOut方法: 打印图表。 @H_301_10@ ChartWizard方法:修改给定图表的属性,其语法为: @H_301_10@ ChartWizard(Source,Gallery,Format,P1otBy,CategoryLabels,SeriesLabels,HasLegend,Title,CategoryTitle,ValueTitle,ExtraTitle)@H_301_10@ 其中: @H_301_10@ Source:包含新图表的源数据的区域。如省略,将修改活动图表工作表或活动工作表中处于选定状态的嵌人式图表。 @H_301_10@ Gallery:图表类型,其值可为下列常量之一:xlArea,x1Bar,xlColumn,xlLine,x1Pie,xlRadar,x1XYScatter,xlCombination,x13DArea,x13Dbar,x13DColumn,x13DLine,x13Dpie,x13 Dsurface,xlDoughnut或xlDefaultAutoFormat。@H_301_10@ Format:内置自动套用格式的编号。如省略,将选择默认值。 @H_301_10@ P1otBy:指定系列中的数据是来自行(xlRows)还是列(xlColumns)。 @H_301_10@ CategoryLabels:表示包含分类标志的源区域内行数或列数的整数。 @H_301_10@ SeriesLabels:表示包含系列标志的源区域内行数或列数的整数。 @H_301_10@ HasLegend:若指定True,则图表将具有图例。 @H_301_10@ Title:图表标题文字。 @H_301_10@ CategoryTitle:分类标题文字。 @H_301_10@ ValueTitle:数值轴标题文字。 @H_301_10@ ExtraTitle:三维图表的系列轴标题,或二维图表的第二数值轴标题。 @H_301_10@ 可组合使用Add方法和ChartWizard方法,以创建包含工作表中数据的图表工作表。下例基于工作表“Sheetl”中单元格区域“A1:A20”中的数据生成新的折线图并打印。@H_301_10@ With Charts.Add @H_301_10@ ChartWizard source:=Worksheets ("sheet1").Range_ @H_301_10@ ("a1:a20"),gallery:=xlLine,title:=“折线图表” @H_301_10@ Printout @H_301_10@ End With @H_301_10@ @H_301_10@ 5)使用Excel工作表函数 @H_301_10@ 在VB语句中可使用大部分的Excel工作表函数,可通过WorksheetFunction对象调用Excel工作表函数。下面的Sub过程用Min工作表函数求出指定区域中单元格的最小值,并通过消息框显示结果值。@H_301_10@ Sub UserFunction() @H_301_10@ Dim myRange As Range @H_301_10@ Set myRange=Worksheets ("Sheet1").Range("B2:F10") @H_301_10@ answer=Application.WorksheetFunction.Min(myRange) @H_301_10@ MsgBox answer @H_301_10@ End Sub @H_301_10@ 如果使用以区域引用为参数的工作表函数,必须指定一个Range对象。如可用Match工作表函数对A1:A10区域的所有单元格进行搜索。 @H_301_10@ Sub FindFirst() @H_301_10@ myVar=Application.WorksheetFunction.Match_ @H_301_10@ (9,orksheets( 1).Range("A1:A10"),0) @H_301_10@ MsgBox myVar @H_301_10@ End Sub @H_301_10@ 要在单元格中插人工作表函数,可将该函数指定为对应于Range对象的Formula属性值。在以下示例中,将当前工作簿Sheetl内A1:B3区域的Formula属性指定为RAND工作表函数(此函数产生二个随机数)。@H_301_10@ Sub InsertFormula() @H_301_10@ Worksheets ("Sheet1" ).Range("A1:B3").Formula="RAND()" @H_301_10@ End Sub @H_301_10@ 以上简要介绍了Excel对象模型中部分对象及其属性方法,更详细的信息可参阅Excel 2000帮助中的“Microsoft Excel Visual Basic参考”一节的内容。实际上,Microsoft Office家族的Word,PowerPoint,Access和Project等应用程序都可以在VB应用程序中调用,其原理和步骤完全相同,只是其对象模型有所不同而已。@H_301_10@ @H_301_10@ 4、示例: @H_301_10@ 首先建立一个窗体(FORM1),在窗体中加入一个DATA控件和一按钮,引用Microsoft office/9.shtml' target='_blank' >Excel类型库:从"工程"菜单中选择"引用"栏;选择Microsoft Excel 9.0 Object Library;选择"确定"。@H_301_10@ @H_301_10@ 在FORM的LOAD事件中加入: @H_301_10@ Data1.DatabaseName = 数据库名称 @H_301_10@ Data1.RecordSource = 表名 @H_301_10@ Data1.Refresh @H_301_10@ 在按钮的CLICK事件中加入 @H_301_10@ Dim Irow,Icol As Integer @H_301_10@ Dim Irowcount,Icolcount As Integer @H_301_10@ Dim Fieldlen() "存字段长度值 @H_301_10@ Dim xlApp As Excel.Application @H_301_10@ Dim xlBook As Excel.Workbook @H_301_10@ Dim xlSheet As Excel.Worksheet @H_301_10@ Set xlApp = CreateObject("Excel.Application") @H_301_10@ Set xlBook = xlApp.Workbooks.Add @H_301_10@ Set xlSheet = xlBook.Worksheets(1) @H_301_10@ With Data1.Recordset.MoveLast @H_301_10@ If .RecordCount < 1 Then @H_301_10@ MsgBox ("Error 没有记录!") @H_301_10@ Exit Sub @H_301_10@ End If @H_301_10@ Irowcount = .RecordCount "记录总数 @H_301_10@ Icolcount = .Fields.Count "字段总数 @H_301_10@ ReDim Fieldlen(Icolcount).MoveFirst @H_301_10@ For Irow = 1 To Irowcount + 1 @H_301_10@ For Icol = 1 To Icolcount @H_301_10@ Select Case Irow @H_301_10@ Case 1 "在Excel中的第一行加标题 @H_301_10@ xlSheet.Cells(Irow,Icol).Value = .Fields(Icol - 1).Name @H_301_10@ Case 2 "将数组FIELDLEN()存为第一条记录的字段长 @H_301_10@ If IsNull(.Fields(Icol - 1)) = True Then @H_301_10@ Fieldlen(Icol) = LenB(.Fields(Icol - 1).Name) @H_301_10@ Else @H_301_10@ Fieldlen(Icol) = LenB(.Fields(Icol - 1)) @H_301_10@ End If @H_301_10@ xlSheet.Columns(Icol).ColumnWidth = Fieldlen(Icol) @H_301_10@ xlSheet.Cells(Irow,Icol).Value = .Fields(Icol - 1) @H_301_10@ Case Else @H_301_10@ Fieldlen1 = LenB(.Fields(Icol - 1)) @H_301_10@ If Fieldlen(Icol) < Fieldlen1 Then @H_301_10@ xlSheet.Columns(Icol).ColumnWidth = Fieldlen1 @H_301_10@ Fieldlen(Icol) = Fieldlen1 @H_301_10@ Else @H_301_10@ xlSheet.Columns(Icol).ColumnWidth = Fieldlen(Icol) @H_301_10@ End If @H_301_10@ xlSheet.Cells(Irow,Icol).Value = .Fields(Icol - 1) @H_301_10@ End Select @H_301_10@ Next @H_301_10@ If Irow <> 1 Then @H_301_10@ If Not .EOF Then .MoveNext @H_301_10@ End If @H_301_10@ Next @H_301_10@ With xlSheet @H_301_10@ .Range(.Cells(1,1),.Cells(1,Icol - 1)).Font.Name = "黑体" @H_301_10@ .Range(.Cells(1,Icol - 1)).Font.Bold = True @H_301_10@ .Range(.Cells(1,.Cells(Irow,Icol - 1)).Borders.LineStyle = xlContinuous@H_301_10@ End With @H_301_10@ xlApp.Visible = True @H_301_10@ xlBook.Save @H_301_10@ Set xlApp = Nothing @H_301_10@ End With

(2)VB中后台打开Excel文件

某些时候需要打开Excel文件获取或者写入数据,但又不希望跳出打开的Excel文件窗口,可以用下面的代码: @H_301_10@ Dim eb As New excel.Application,wb as excel.Workbook @H_301_10@ Set wb = eb.Application.Workbooks.Open(FileName:=nameOfFile,ReadOnly:= False) ' open @H_301_10@ ' do your work @H_301_10@ wb.Close True ' save and close
原理:New Excel.Application新建了一个Excel实例,这个实例默认不可见。具体而言,获取Excel.Application实例有两种方式: @H_301_10@ Dim eb As Excel.Application @H_301_10@ Set eb = CreateObject(," Excel.Application") @H_301_10@ ' 新建Excel实例,同dim eb as new Excel.Application @H_301_10@ Set eb = GetObject(," Excel.Application") @H_301_10@ ' 从Windows环境获取Excel实例,如果当前没有打开的Excel窗口,将出现错误

如果对是否后台打开没有要求的话,最好结合上面两种方式获取Excel实例:' 获取Excel实例,如果当前已经有excel窗口,则直接获取当前实例,否则新建实例@H_301_10@ Function GetExcelApp() As Excel.Application@H_301_10@ On ErrorResume Next@H_301_10@ Set GetExcelApp = GetObject(,"Excel.Application")@H_301_10@ If Err.Number > 0 Then Err.Clear: Set GetExcelApp = New Excel.Application@H_301_10@ End Function

猜你在找的VB相关文章