用EXCEL组件简化VB编程的一种方法
2006-02-27 11:54:41 来源:WEB开发网核心提示:具体使用编辑器步骤如下:进入Excel97后,用鼠标点击菜单栏中的“工具”按钮,用EXCEL组件简化VB编程的一种方法,选择“宏”,再选择“VB编辑器”,并且节约调试程序和定位调用的时间,这样就可以把VisualBasic和EXCEL有机的结合在一起,即出现类似于VB的标准窗口,由于“VB编辑器”的编辑界面非常类似于“
具体使用编辑器步骤如下:进入Excel97后,用鼠标点击菜单栏中的“工具”按钮,选择“宏”,再选择“VB编辑器”。即出现类似于VB的标准窗口。
由于“VB编辑器”的编辑界面非常类似于“VisualBasic”的界面。所以我们可以从它的控件“工程资源管理器”中插入需要的“添加用户窗体、添加模块、添加类模块”,并且从“属性窗口”中加入属性。
例如,我们可以制定一个表格处理定位的窗体,通过程序来实现数据定位和循环调用过程。
PublicdecideAsBoolean
PRivateSubCommandButton1_Click()
exchange
IfdecideThen
UnloadMe
Else
TextBox1.Text=""
EndIf
EndSub
Subexchange()
IfNotdecideday(TextBox1.Text)ThenGoToerror
decide=True
DimsqlAsString
DimdbAsDatabase
DimrsAsRecordset
sql="SELECT*From数据表"
sql=sql "WHERE(((数据表.日期)=#" TextBox1.Text "#))"
Setdb=OpenDatabase(application.ThisWorkbook.Path "gl.mdb")
Setrs=db.OpenRecordset(sql,dbOpenDynaset)
Ifrs.EOFThen
MsgBox("此日期无数据")
ExitSub
EndIf
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
Dimsql1AsString
Dimdb1AsDatabase
Dimrs1AsRecordset
sql1="SELECT*From代码字典"
sql1=sql1 "WHERE(((代码字典.代码)="&daima1&"))"
Setdb1=OpenDatabase(Application.ThisWorkbook.Path "gl.mdb")
Setrs1=db1.OpenRecordset(sql1,dbOpenDynaset)
Sheet1.Range("h41").Value=rs1.Fields("代码字典名称")
ExitSub
error:
MsgBox("日期输入错误")
decide=False
EndSub
PrivateSubTextBox1_Change()
EndSub
PrivateSubUserForm_Activate()
dyaaa.Top=30
dybbb.Left=230
EndSub
VB是标准的面向对象编程语言可视编程,采用事件驱动的编程技术。所以可以直接调用VB编辑器所写的程序,简化以往较为繁琐的一些步骤。
由于用户的需求较多,VB可以通过直接调用OFFICE组件EXCEL,进而直接调用VB编辑器实现表格处理,以简化程序的编写。
VB程序中直接调用EXCEL的格式如下:
PrivateSubmenudy_Click(IndexAsInteger)这是一个打印菜单
SelectCaseIndex
Case0
OnErrorGoToLast
diaoyong=Shell("D:ProgramFilesMicrosoftOfficeOfficeEXCEL.EXEc:glgl.xls",1)
Case1
OnErrorGoToLast1作为空表处理
diaoyong=Shell("D:ProgramFilesMicrosoftOfficeOfficeEXCEL.EXEc:glgly.xls",1)
Case3
EXIT
EndSelect
ExitSub
Last:
diaoyong=Shell("EXCEL.EXEc:glgl.xls",1)
ExitSub
Last1:
diaoyong=Shell("EXCEL.EXEc:glgly.xls",1)
EndSub
具体的表格数据处理可以由EXCEL自动完成,因此就简化VB编程的步骤,并且节约调试程序和定位调用的时间。这样就可以把VisualBasic和EXCEL有机的结合在一起,使编程更加实用。->
由于“VB编辑器”的编辑界面非常类似于“VisualBasic”的界面。所以我们可以从它的控件“工程资源管理器”中插入需要的“添加用户窗体、添加模块、添加类模块”,并且从“属性窗口”中加入属性。
例如,我们可以制定一个表格处理定位的窗体,通过程序来实现数据定位和循环调用过程。
PublicdecideAsBoolean
PRivateSubCommandButton1_Click()
exchange
IfdecideThen
UnloadMe
Else
TextBox1.Text=""
EndIf
EndSub
Subexchange()
IfNotdecideday(TextBox1.Text)ThenGoToerror
decide=True
DimsqlAsString
DimdbAsDatabase
DimrsAsRecordset
sql="SELECT*From数据表"
sql=sql "WHERE(((数据表.日期)=#" TextBox1.Text "#))"
Setdb=OpenDatabase(application.ThisWorkbook.Path "gl.mdb")
Setrs=db.OpenRecordset(sql,dbOpenDynaset)
Ifrs.EOFThen
MsgBox("此日期无数据")
ExitSub
EndIf
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
Dimsql1AsString
Dimdb1AsDatabase
Dimrs1AsRecordset
sql1="SELECT*From代码字典"
sql1=sql1 "WHERE(((代码字典.代码)="&daima1&"))"
Setdb1=OpenDatabase(Application.ThisWorkbook.Path "gl.mdb")
Setrs1=db1.OpenRecordset(sql1,dbOpenDynaset)
Sheet1.Range("h41").Value=rs1.Fields("代码字典名称")
ExitSub
error:
MsgBox("日期输入错误")
decide=False
EndSub
PrivateSubTextBox1_Change()
EndSub
PrivateSubUserForm_Activate()
dyaaa.Top=30
dybbb.Left=230
EndSub
VB是标准的面向对象编程语言可视编程,采用事件驱动的编程技术。所以可以直接调用VB编辑器所写的程序,简化以往较为繁琐的一些步骤。
由于用户的需求较多,VB可以通过直接调用OFFICE组件EXCEL,进而直接调用VB编辑器实现表格处理,以简化程序的编写。
VB程序中直接调用EXCEL的格式如下:
PrivateSubmenudy_Click(IndexAsInteger)这是一个打印菜单
SelectCaseIndex
Case0
OnErrorGoToLast
diaoyong=Shell("D:ProgramFilesMicrosoftOfficeOfficeEXCEL.EXEc:glgl.xls",1)
Case1
OnErrorGoToLast1作为空表处理
diaoyong=Shell("D:ProgramFilesMicrosoftOfficeOfficeEXCEL.EXEc:glgly.xls",1)
Case3
EXIT
EndSelect
ExitSub
Last:
diaoyong=Shell("EXCEL.EXEc:glgl.xls",1)
ExitSub
Last1:
diaoyong=Shell("EXCEL.EXEc:glgly.xls",1)
EndSub
具体的表格数据处理可以由EXCEL自动完成,因此就简化VB编程的步骤,并且节约调试程序和定位调用的时间。这样就可以把VisualBasic和EXCEL有机的结合在一起,使编程更加实用。->
更多精彩
赞助商链接