新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 软件开发 > 开发语言 > VB教程 > 正文:用EXCEL组件简化VB编程

用EXCEL组件简化VB编程

新客网 XKER.COM 2007-02-01 来源: 收藏本文
  使用编辑器步骤如下:进入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有机的结合在一起,使编程更加实用。
收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐