用EXCEL组件简化VB编程的一种方法
2008-02-23 06:52:51来源:互联网 阅读 ()
由于“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时快速选择文本
下一篇: 用ParamArray接收任意个参数
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
下一篇:VB数组小技巧一则
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash