庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>程序设计>VB专区>编程技巧>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

用EXCEL组件简化VB编程的一种方法

 作者:本站收集   日期:2005-8-4 11:33:00
字号选择〖 〗/ 双击滚屏 单击停止   
具体使用编辑器步骤如下:进入EXCEL97后,用鼠标点击菜单栏中的“工具”按钮,选择“宏”,再选择“VB编辑器”。即出现类似于VB的标准窗口。

   由于“VB编辑器”的编辑界面非常类似于“Visual Basic”的界面。所以我们可以从它的控件“工程资源管理器”中插入需要的“添加用户窗体、添加模块、添加类模块”,并且从“属性窗口”中加入属性。

   例如,我们可以制定一个表格处理定位的窗体,通过程序来实现数据定位和循环调用过程。

   Public decide As Boolean

   Private Sub CommandButton1_Click()

   exchange

   If decide Then

   Unload Me

   Else

   TextBox1.Text = ""

   End If

   End Sub

   Sub exchange()

   If Not decideday(TextBox1.Text) Then GoTo error

   decide = True

   Dim sql As String

   Dim db As Database

   Dim rs As Recordset

   sql = "SELECT * From 数据表"

   sql = sql + " WHERE (((数据表.日期)=#" + TextBox1.Text + "#))"

   Set db = OpenDatabase(Application.ThisWorkbook.Path + "gl.mdb")

   Set rs = db.OpenRecordset(sql, dbOpenDynaset)

   If rs.EOF Then

   MsgBox ("此日期无数据")

   Exit Sub

   End If

   daima1 = rs.Fields("代码")

   (以下为数据表格中的定位及调用)

   Sheet1.Range("e5").Value = rs.Fields("日期")

   Sheet1.Range("f7").Value = rs.Fields("数据表记录")

   Sheet1.Range("d12").Value = rs.Fields("实数100")

   Sheet1.Range("d14").Value = rs.Fields("实数50")

   Sheet1.Range("d16").Value = rs.Fields("实数10")

   Sheet1.Range("d18").Value = rs.Fields("实数5")

   Sheet1.Range("d20").Value = rs.Fields("实数2")

   Sheet1.Range("d22").Value = rs.Fields("实数1")

   Sheet1.Range("h12").Value = rs.Fields("其他100")

   Sheet1.Range("h14").Value = rs.Fields("其他50")

   Sheet1.Range("h16").Value = rs.Fields("其他10")

   Sheet1.Range("h18").Value = rs.Fields("其他5")

   Sheet1.Range("h20").Value = rs.Fields("其他2")

   Sheet1.Range("h22").Value = rs.Fields("其他1")

   Sheet1.Range("d38").Value = Sheet1.Range("d12").Value * 100 + Sheet1.Range("d14").Value * 50 + Sheet1.Range("d16").Value * 10 + Sheet1.Range("d18").Value * 5 + Sheet1.Range("d20").Value * 2 + Sheet1.Range("d22").Value

   Sheet1.Range("h38").Value = Sheet1.Range("h12").Value * 100 + Sheet1.Range("h14").Value * 50 + Sheet1.Range("h16").Value * 10 + Sheet1.Range("h18").Value * 5 + Sheet1.Range("h20").Value * 2 + Sheet1.Range("h22").Value

   Dim sql1 As String

   Dim db1 As Database

   Dim rs1 As Recordset

   sql1 = "SELECT * From 代码字典"

   sql1 = sql1 + " WHERE (((代码字典.代码)=" & daima1 & "))"

   Set db1 = OpenDatabase(Application.ThisWorkbook.Path + "gl.mdb")

   Set rs1 = db1.OpenRecordset(sql1, dbOpenDynaset)

   Sheet1.Range("h41").Value = rs1.Fields("代码字典名称")

   Exit Sub

   error:

   MsgBox ("日期输入错误")

   decide = False

   End Sub

   Private Sub TextBox1_Change()

   End Sub

   Private Sub UserForm_Activate()

   dyaaa.Top = 30

   dybbb.Left = 230

   End Sub

   VB是标准的面向对象编程语言可视编程,采用事件驱动的编程技术。所以可以直接调用VB编辑器所写的程序,简化以往较为繁琐的一些步骤。

   由于用户的需求较多,VB可以通过直接调用OFFICE组件EXCEL,进而直接调用VB编辑器实现表格处理,以简化程序的编写。

   VB程序中直接调用EXCEL 的格式如下:

   Private Sub menudy_Click(Index As Integer) 这是一个打印菜单

   Select Case Index

   Case 0

   On Error GoTo Last

   diaoyong = Shell("D:Program FilesMicrosoft OfficeOfficeEXCEL.EXE c:glgl.xls", 1)

   Case 1

   On Error GoTo Last1 作为空表处理

   diaoyong = Shell("D:Program FilesMicrosoft OfficeOfficeEXCEL.EXE c:glgly.xls", 1)

   Case 3

   EXIT

   End Select

   Exit Sub

   Last:

   diaoyong = Shell("EXCEL.EXE c:glgl.xls", 1)

   Exit Sub

   Last1:

   diaoyong = Shell("EXCEL.EXE c:glgly.xls", 1)

   End Sub

   具体的表格数据处理可以由EXCEL自动完成,因此就简化VB编程的步骤,并且节约调试程序和定位调用的时间。这样就可以把Visual Basic和 EXCEL有机的结合在一起,使编程更加实用。
上一篇:在GotFocus时快速选择文本    下一篇:用VB控制EXCEL生成报表  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 本站收集
信息来源: 网络 录入时间: 2005-8-4 11:33:00
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿