【转】如何实现vb与excel的无缝连接 vb和sql怎么连接

   2023-02-08 学习力0
核心提示:何处转来已无所知......vb是常用的应用软件开发工具之一,由于vb的报表功能有限,而且一但报表格式发生变化,就得相应修改程序,给应用软件的维护工作带来极大的不便。因此有很多程序员现在已经充分利用execl的强大报表功来实现报表功能。但由于vb与excel由于

何处转来已无所知......

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.application 
dim xlbook as excel.workbook 
dim 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 if 
end sub 

private 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对象 
 end 
end 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 #1 
end sub 
sub 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的无缝连接。

 

 

 

 

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • Windows API Reference for C#, VB.NET
    不错的.net 下用API的参考站点地址在:http://www.webtropy.com/articles/Win32-API-DllImport-art9.asp 下面摘抄分类,便于大家直接就拿来用: File, Memory, Process, Threading, Time, Console, and Comm control(kernel32.dll) _hread_hwrite_lclose_lcr
    03-16
  • 一个基于API的VB.net串口通讯类 vbnet串口通信
    VB.net的串口通讯支持总是让人觉得有所不足,在使用VB6的MsComm32.ocx时,很多人都会在VB.net的开发中觉得很困扰。    这里讲述的VB.net串口通讯类使用native代码,并且它是通API调用实现的,你会发现VB.net的串口通讯就是这么简单。    在说明如何使
    02-12
  • [VB][ASP.NET]FileUpload控件「批次上传 / 多档
    FileUpload控件「批次上传 / 多档案同时上传」的范例 (VB语法) http://www.dotblogs.com.tw/mis2000lab/archive/2008/05/14/3986.aspx    FileUpload控件真的简单好用,不使用它来作批次上传,却要改用别的方法,实在不聪明。要用就一次用到底,公开File
    02-10
  • 第八章 VB中ActiveX控件的使用
    轉自:http://wwww.hyit.edu.cn/edu/vb/study/index.htm第八章          VB中ActiveX控件的使用8.1  概述     这里的ActiveX控件是指VB标准工具箱里没有的控件,用时需从“工程”菜单里选择“部件…”(或右键单击工具箱,从快捷菜单中选择“部
    02-10
  • 第二章 VB的界面设计
    轉自:http://wwww.hyit.edu.cn/edu/vb/study/index.htm第二章         VB的界面设计2.1  VB用户界面设计基础1. 概述   界面的设计有两步:先绘制控件,然后确定控件属性。   绘制控件:在工具箱里单击想画的控件,在窗体里按下鼠标并拖曳,然后
    02-10
  • C#/VB.NET 获取Excel中图片所在的行、列坐标位置
    C#/VB.NET 获取Excel中图片所在的行、列坐标位
    本文以C#和vb.net代码示例展示如何来获取Excel工作表中图片的坐标位置。这里的坐标位置是指图片左上角顶点所在的单元格行和列位置,横坐标即顶点所在的第几列、纵坐标即顶点所在的第几行。下面是获取图片位置的详细方法及步骤。【程序环境】按照如下方法来引
    02-09
  • VB操作XML
    VB操作XML
    XSL(可扩展样式表语言)是对CSS的一种扩展,功能比CSS强大得多。XML链接是在HTML链接的功能之上加以扩展,可以支持更为复杂的链接,通过XML链接,不仅可以在XML文件之间建立链接,还可以建立其他类型数据之间的链接,其规范分为三个部分:XLink语言,XPointe
    02-09
  • VB6多线程,关键段操作 vb6.0 多线程
    Option Explicit Declare Function GetLastError Lib "kernel32" () As Long 'Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long 'Declare Sub ExitThread Lib "kernel32" (Optional ByVal dwExitCode
    02-09
  • VB.NET调用IE,并且等待
                Dim p As New Process            '获得URL            aURL = GetURL()            '获得IE路径            p.StartInfo.FileName = System.Environment.GetFolderPath( _ 
    02-09
  • vb的VSFlexGrid控件 vb msflexgrid
    多行选中VSFlexGrid的SelectionMode = flexSelectionListBox,现在可以配合Ctrl进行多行选择循环取值用vsflexgrid.SelectedRows 可以得到你选择的行的总数量然后用循环可以得到具体的行中具体列的内容Dim Temp  As StringDim i As IntegerFor i =
    02-09
点击排行