上海知名 网站设计公司,wordpress连接小程序,阳江网签,郑州粒米seo外包Visual Basic简称(VB)是设计Windows应用程序强有力的开发工具#xff0c;“全球绝大多数Windows应用程序都是用VB开发的”#xff1b; Excel是目前使用最广泛的办公应用软件之一#xff0c;它具有强大的数学分析与计算功能#xff0c;包括很多VB没有的求值数学表达式的函数… 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 VBExcelCreateObject (Excel.Application) 字符串“Excel.Application”是提供Excel应用程序的编程ID这个变量引用Excel应用程序本身。 b用GetO场ect函数打开已存在的对象引用 Set AppExcelGetObject(SAMP.XLS) 上面语句打开文件SAMP.XLS。 3、Application对象常用的属性、方法 属性、方法方法Visible属性取True或False表明Excel应用程序是否可见。Left,Top属性Excel窗口的位置Height, Width属性Excel窗口的大小WindowState属性指定窗口的状态取XIMaximized(最大化)X1 Minimized(最小化)x1 Normal(缺省)。Quit方法退出Microsoft ExcelCalculate方法重新计算所有打开的工作簿、工作表或单元格。Evaluate方法求值数学表达式并返回结果。 示例1求值数学表达式 Dim VBExcel As ObjectSet VBExcelCreateObject (Excel.Application)XVBExcel. Evaluate (35*(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打印的起始页号。如省略将从起始位置开始打印。 To打印的终止页号。如省略将打印至最后一页。 Copies要打印的份数。如省略将只打印一份。 Preview如果为True则Excel打印指定对象之前进行打印预览。如果为False或省略则立即打印该对象。 Printer设置活动打印机的名称。 ToFile如果为True则打印输出到文件。 Collate如果为True则逐份打印每份副本。 下面语句将活动工作簿的2到5页打印3份ActiveWorkbook.PrintOut From2 To 5 Copies3 示例2生成、保存、关闭工作簿Dim VBExcel As Excel.ApplicationSet VBExcel CreateObject(Excel.Application)With VBExcel.Workbooks.AddWith ActiveWorkbook.Save AsC \Temp \OUTPUT.XLS.CloseEnd With.QuitEnd With 2、使用工作表 Sheets集合表示工作簿中所有的工作表。可以通过Sheets集合来访问、激活、增加、更名和删除工作表。一个Worksheet对象代表一个工作表。 常用的属性、方法有属性、方法意义Worksheets属性返回Sheets集合。Name属性工作表更名。Add方法创建新工作表并将其添加到工作簿中。Select方法选择工作表。Copy方法复制工作表。Move方法将指定工作表移到工作簿的另一位置。Delete方法删除指定工作表。PrintOut方法打印工作表。 示例3将C盘工作簿中的工作表复制到A盘工作簿中Dim VBExcel As Excel.ApplicationSet VBExcelCreateObject(Excel.Application)With VBExcel .Workbooks.Open C\Temp\OUTPUT.XLS .Workbooks.OpenA\OUTPUT1.XLS .Workbooks(OUTPUT.XLS).Sheets (Sales).Copy .Workbooks(OUTPUT1.XLS) .Workbooks(OUTPUT1.XLS).Save .Workbooks(OUTPUT.XLS).Close .Workbooks(OUTPUTI.XLS).Close .QuitEnd 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”中单元格区域“A1A20”中的数据生成新的折线图并打印。With Charts.Add .ChartWizard sourceWorksheets (sheet1).Range (a1a20),galleryxlLine, title“折线图表” .PrintoutEnd With 5、使用Excel工作表函数 在VB语句中可使用大部分的Excel工作表函数可通过WorksheetFunction对象调用Excel工作表函数。下面的Sub过程用Min工作表函数求出指定区域中单元格的最小值并通过消息框显示结果值。Sub UseFunction()Dim myRange As RangeSet myRangeWorksheets (Sheet1).Range(B2F10)answerApplication.WorksheetFunction.Min(myRange)MsgBox answerEnd Sub 如果使用以区域引用为参数的工作表函数必须指定一个Range对象。如可用Match工作表函数对A1A10区域的所有单元格进行搜索。Sub FindFirst()my VarApplication.WorksheetFunction.Match (9, Worksheets( 1).Range(A1A10)0)MsgBox myVarEnd Sub 要在单元格中插人工作表函数可将该函数指定为对应于Range对象的Formula属性值。在以下示例中将当前工作簿Sheetl内A1B3区域的Formula属性指定为RAND工作表函数(此函数产生二个随机数)。Sub InsertFormula()Worksheets (Sheet1 ).Range(A1B3).FormulaRAND()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