VB 操作 Execl

VB Execl  本文提出的在Visual Basic中创建Word文档的方法基于对象模型,实用性强,也可以用于其它支持ActiveX的开发平台中。VB是常用的应用软件开发工具之一,由于VB的报表功能有限,而且一但报表格式发生变化,就得相应修改程序,给应用软件的维护工作带来极大的不便。因此有很多程序员现在已经充分利用EXECL的强大报表功来实现报表功能。但由于VB与EXCEL由于分别属于不同的应用系统,如何把它们有机地结合在一起,是一个值得我们研究的课题。  一、 VB读写EXCEL表:  VB本身提自动功能可以读写EXCEL表,其方法如下:  1、在工程中引用Microsoft Excel类型库:  从"工程"菜单中选择"引用"栏;选择Microsoft Excel 9.0 Object Library(EXCEL2000),然后选择"确定"。表示在工程中要引用EXCEL类型库。  2、在通用对象的声明过程中定义EXCEL对象:Dim xlApp As Excel.ApplicationDim xlBook As Excel.WorkBookDim xlSheet As Excel.Worksheet  3、在程序中操作EXCEL表常用命令:Set xlApp = CreateObject("Excel.Application") '创建EXCEL对象Set xlBook = xlApp.Workbooks.Open("文件名") '打开已经存在的EXCEL工件簿文件xlApp.Visible = True '设置EXCEL对象可见(或不可见)Set xlSheet = xlBook.Worksheets("表名") '设置活动工作表xlSheet.Cells(row,col) =值 '给单元格(row,col)赋值xlSheet.PrintOut '打印工作表xlBook.Close (True) '关闭工作簿xlApp.Quit '结束EXCEL对象Set xlApp = nothing '释放xlApp对象xlBook.RunAutoMacros (xlAutoOpen) '运行EXCEL启动宏xlBook.RunAutoMacros (xlAutoClose) '运行EXCEL关闭宏  4、在运用以上VB命令操作EXCEL表时,除非设置EXCEL对象不可见,否则VB程序可继续执行其它操作,也能够关闭EXCEL,同时也可对EXCEL进行操作。但在EXCEL操作过程中关闭EXCEL对象时,VB程序无法知道,如果此时使用EXCEL对象,则VB程序会产生自动错误。形成VB程序无法完全控制EXCEL的状况,使得VB与EXCEL脱节。  二、 EXCEL的宏功能:  EXCEL提供一个Visual Basic编辑器,打开Visual Basic编辑器,其中有一工程属性窗口,点击右键菜单的"插入模块",则增加一个"模块1",在此模块中可以运用Visual Basic语言编写函数和过程并称之为宏。其中,EXCEL有两个自动宏:一个是启动宏(Sub Auto_open()),另一个关闭宏(Sub Auto_Close())。它们的特性是:当用EXCEL打含有启动宏的工簿时,就会自动运行启动宏,同理,当关闭含有关闭宏的工作簿时就会自动运行关闭宏。但是通过VB的自动功能调用EXCEL工作表时,启动宏和关闭宏不会自动运行,而需要在VB中通过命令xlBook.RunAutoMacros (xlAutoOpen)和xlBook.RunAutoMacros (xlAutoClose) 来运行启动宏和关闭宏。  三、 VB与EXCEL的相互勾通:  充分利用EXCEL的启动宏和关闭宏,可以实现VB与EXCEL的相互勾通,其方法如下:  在EXCEL的启动宏中加入一段程序,其功能是在磁盘中写入一个标志文件,同时在关闭宏中加入一段删除此标志文件的程序。VB程序在执行时通过判断此标志文件存在与否来判断EXCEL是否打开,如果此标志文件存在,表明EXCEL对象正在运行,应该禁止其它程序的运行。如果此标志文件不存在,表明EXCEL对象已被用户关闭,此时如果要使用EXCEL对象运行,必须重新创建EXCEL对象。  四、举例:  1、在VB中,建立一个FORM,在其上放置两个命令按钮,将Command1的Caption属性改为EXCEL,Command2的Caption属性改为End。然后在其中输入如下程序:Dim xlApp As Excel.Application '定义EXCEL类Dim xlBook As Excel.Workbook '定义工件簿类Dim xlsheet As Excel.Worksheet '定义工作表类Private Sub Command1_Click() '打开EXCEL过程 If Dir("D:/temp/excel.bz") = "" Then '判断EXCEL是否打开  Set xlApp = CreateObject("Excel.Application") '创建EXCEL应用类  xlApp.Visible = True '设置EXCEL可见  Set xlBook = xlApp.Workbooks.Open("D:/temp/bb.xls") '打开EXCEL工作簿  Set xlsheet = xlBook.Worksheets(1) '打开EXCEL工作表  xlsheet.Activate '激活工作表  xlsheet.Cells(1,1) = "abc" '给单元格1行驶列赋值  xlBook.RunAutoMacros (xlAutoOpen) '运行EXCEL中的启动宏 Else  MsgBox ("EXCEL已打开") End IfEnd SubPrivate Sub Command2_Click() If Dir("D:/temp/excel.bz") <> "" Then '由VB关闭EXCEL  xlBook.RunAutoMacros (xlAutoClose) '执行EXCEL关闭宏  xlBook.Close (True) '关闭EXCEL工作簿   xlApp.Quit '关闭EXCEL End If Set xlApp = nothing '释放EXCEL对象 EndEnd Sub  2、在D盘根目录上建立一个名为Temp的子目录,在Temp目录下建立一个名为"bb.xls"的EXCEL文件。  3、在"bb.xls"中打开Visual Basic编辑器,在工程窗口中点鼠标键选择插入模块,在模块中输入入下程序存盘:Sub auto_open() Open "d:/temp/excel.bz" For Output As #1 '写标志文件 Close #1End SubSub auto_close() Kill "d:/temp/excel.bz" '删除标志文件End Sub  4、运行VB程序,点击EXCEL按钮可以打开EXCEL系统,打开EXCEL系统后,VB程序和EXCEL分别属两个不同的应用系统,均可同时进行操作,由于系统加了判断,因此在VB程序中重复点击EXCEL按钮时会提示EXCEL已打开。如果在EXCEL中关闭EXCEL后再点EXCEL按钮,则会重新打开EXCEL。而无论EXCEL打开与否,通过VB程序均可关闭EXCEL。这样就实现了VB与EXCEL的无缝连接。-------1.创建Excel对象  eole=CREATEOBJECT(′Excel.application′)  2.添加新工作簿  eole.Workbooks.add  3.设置第3个工作表为激活工作表  eole.Worksheets(″sheet3″).Activate  4.打开指定工作簿  eole.Workbooks.Open(″c:/temp/ll.xls″)  5.显示Excel窗口  eole.visible=.t.  6.更改Excel标题栏  eole.Caption=″VFP应用程序调用Microsoft Excel″  7.给单元格赋值  eole.cells(1,4).value=XM(XM为数据库字段名)  8.设置指定列的宽度(单位:字符个数)  eole.ActiveSheet.Columns(1).ColumnWidth=5  9.设置指定行的高度(单位:磅)  eole.ActiveSheet.Rows(1).RowHeight=1/0.035  (设定行高为1厘米,1磅=0.035厘米)  10.在第18行之前插入分页符  eole.Worksheets(″Sheet1″).Rows(18).PageBreak=1  11.在第4列之前删除分页符  eole.ActiveSheet.Columns(4).PageBreak=0  12.指定边框线宽度(Borders参数如下)  ole.ActiveSheet.Range(″b3:d3″).Borders(2).Weight=3  13.设置四个边框线条的类型  eole.ActiveSheet.Range(″b3:d3″).Borders(2).Linestyle=1  (其中Borders参数:1-左、2-右、3-顶、4-底、5-斜、6-斜/;Linestyle值:1与7-细实、2-细虚、4-点虚、9-双细实线)  14.设置页眉  eole.ActiveSheet.PageSetup.CenterHeader=″报表1″  15.设置页脚  eole.ActiveSheet.PageSetup.CenterFooter=″第&P页″  16.设置页眉到顶端边距为2厘米  eole.ActiveSheet.PageSetup.HeaderMargin=2/0.035  17.设置页脚到底边距为3厘米  eole.ActiveSheet.PageSetup.FooterMargin=3/0.035  18.设置顶边距为2厘米  eole.ActiveSheet.PageSetup.TopMargin=2/0.035  19.设置底边距为4厘米  eole.ActiveSheet.PageSetup.BottomMargin=4/0.035  20.设置左边距为2厘米  veole.ActiveSheet.PageSetup.LeftMargin=2/0.035  21.设置右边距为2厘米  eole.ActiveSheet.PageSetup.RightMargin=2/0.035  22.设置页面水平居中  eole.ActiveSheet.PageSetup.CenterHorizontally=.t.  23.设置页面垂直居中  eole.ActiveSheet.PageSetup.CenterVertically=.t.  24.设置页面纸张大小(1-窄行8 5 11 39-宽行14 11)  eole.ActiveSheet.PageSetup.PaperSize=1  25.打印单元格网线  eole.ActiveSheet.PageSetup.PrintGridlines=.t.  26.拷贝整个工作表  eole.ActiveSheet.UsedRange.copy  27.拷贝指定区域  eole.ActiveSheet.Range(″A1:E2″).copy  28.粘贴  eole.WorkSheet(″Sheet2″).Range(″A1″).PasteSpecial  29.在第2行之前插入一行  eole.ActiveSheet.Rows(2).Insert  30.在第2列之前插入一列  eole.ActiveSheet.Columns(2).Insert  31.设置字体  eole.ActiveSheet.Cells(2,1).Font.Name=″黑体″  32.设置字体大小  eole.ActiveSheet.Cells(1,1).Font.Size=25  33.设置字体为斜体  eole.ActiveSheet.Cells(1,1).Font.Italic=.t.  34.设置整列字体为粗体  eole.ActiveSheet.Columns(1).Font.Bold=.t.  35.清除单元格公式  eole.ActiveSheet.Cells(1,4).ClearContents  36.打印预览工作表  eole.ActiveSheet.PrintPreview  37.打印输出工作表  eole.ActiveSheet.PrintOut  38.工作表另为  eole.ActiveWorkbook.SaveAs(″c:/temp/22.xls″)  39.放弃存盘  eole.ActiveWorkbook.saved=.t.  40.关闭工作簿  eole.Workbooks.close  41.退出Excel  eole.quit-----◆设置新增工作薄的工作表数:oExcel.SheetsInNewWorkbook=1 &&新建工作表数量定为1个◆新增EXCEL工作薄:oExcel.WorkBooks.Add◆当前工作薄工作表总数:oExcel.WorkSheets.Count &&如:lnSheetCnt=oExcel.WorkSheets.count◆新增EXCEL工作表:oExcel.Sheets.Add &&不带参数为增加至当前工作表之前在指定工作表后新建工作表:oExcel.Sheets.Add(,oExcel.Sheets(lnSheet),1,-4167) &&lnSheet为指定表号在最后工作表后新建工作表:oExcel.Sheets.Add(,lnSheetsCnt,-4167) &&lnSheetCnt为工作表总数-----Private Sub Command1_Click()Dim xlApp As Excel.ApplicationDim xlBook As Excel.WorkbookSet xlApp = New Excel.Application' Set xlBook = xlApp.workbooks.Add'创建新的ExcelSet xlBook = xlApp.workbooks.Open("C:/Book1.xls")'打开已有的Excel..........xlBook.Close FalsexlApp.QuitSet xlBook = nothingSet xlApp = nothingEnd Sub

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...