说三道四技术文摘-感悟人生的经典句子
说三道四 > 文档快照

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

HTML文档下载 WORD文档下载 PDF文档下载
VB用EXCEL组件简化VB编程的一种方法

作 者 : 三联商社电脑部 葛岩

   具体使用编辑器步骤如下:进入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有机的结合在一起,使编程更加实用。

NPD:全球智能手机出货量2013年将首次超过功能手机 聚合数据左磊:不走寻常路 做国内最好的数据聚合平台 从程序员到软件商 需要注意些什么? 共享软件海外营销策略与实战(上海站) 直接拿来用!最火的Android开源项目(完结篇) 一步加入云生态系统 参加第五届中国云计算大会的十大理由 传苹果iOS7将深度整合Flickr 用户受益最大 Chrome 27来了:页面加载快5% 可同步数据到Google Drive 微软发布新一代游戏主机Xbox One 搭配全新Kinect 2.0体感系统 Unity游戏引擎向iOS与Android开发者免费 Twitter获“下拉刷新”专利 开发者仍可自由使用 复杂产品的响应式设计【流程篇】 使用Javassist库为Bytecode Instrumentation开发JVM Agent 内容解析创业公司Stremor推出4款API 2013中国云计算榜单之三:174家云应用服务商,繁花似锦! 盘点各大云服务提供商:麦当劳=AWS,汉堡王=? BlackBerry Jam亚洲开发者大会9月将在香港开幕 把服务器搬进来:Splashtop在中国搭建Bridging Cloud Web框架全对比第五期 新增Windows环境 前Tumblr首席开发者回忆录:一个人也能开发出好产品 测试者和开发者,为何我们不能友好地相处? 讲师秀之11:何刚谈京东的云机遇 讲师秀之10:武汉大学张焕国教授,可信计算是云计算之成败关键 【上海直播】Windows Azure+世纪互联:中国云计算“烈火烹油” 最新版Chrome浏览器推出全新语音搜索功能 惠普第二财季净利润同比下滑32% PC和服务器销售不佳 讲师秀之11:网易汪源的成长故事 PPT集萃(三):六位国内技术大牛分享巨型平台的打造与应用 聚焦全球移动市场:创新以色列 科技巨头的倾慕之地 Android版Chrome 27浏览器正式上架 机器人——数据中心的新“网管” 我编写了一个dos批处理文件bat,要在bat文件运行后自动关闭dos窗口怎么办? 急救:机器出问题了,大家帮忙看看 谁能谈谈XP的激活问题!? 有问题的问题1 有问题的问题 安装visual studio.net 2003 的问题? 急件!请教了,如何在一个字符串中提取第n次出现的字符? weblogic及EJB属于中间层的吗? 到水园第一件事就是看看斑竹有没有换,嘻嘻,还有谁也是这样的? win2000装好后,设了本地连接的属性,和别的机器一样的设,可就是PING 不通网关 哪有“VB.NET高级编程”和“ADO.NET高级编程”下载?? 请各位帮忙找一个用asp.net写的日历,急用 小弟是菜鸟,请问一下svrmgrl是什么,9I中有吗? 文章分页,而且文章中有大小不等的图片,该如何去做 求《三国霸业2》简体版下载地址? 诸位高手,我碰到一个很棘手ASPNETMENU的问题!急需解决!!(100分)献上! vfw下的视频采集和图象截取的问题请教! 求 《家园-惊世浩劫》简体版 关于浏览器的问题 pb如何调用word文挡? 在使用mfc时选择不同语言,怎么最后编译执行时有??符号(在菜单中) 网络共享安全问题!!!!!!!!!!!!! 我是第一次尝试做网站,碰到了问题,能帮帮我吗? 电话号码的正确性问题? 求教c#中datagrid表格设置 高分求远程开机源代码 希望大家给出: 时间的各种单位(包括汉字名称和英文缩写)及它们的进率关系; 专家近来看一下,很有针对性! 对《c# Primer Plus中文版》书的批判!!!!! 谁能提供teechart在pb中的使用帮助 是否有记录传真机传真的资料(包括传真号码,传真时间,内容) 是否有记录传真机传真的资料(包括传真号码,传真时间,内容) 急救:如何回复fdisk删除的分区 请各位帮忙找一个用asp.net写的日历,急用 我想了解‘Bug 列表‘是怎么回事,最好有例子 各位大哥请帮帮我,如何将下面的vbs转换到c#,不胜感激! 如何控制DataList显示的记录数 请教做过基于snmp方式的入侵检测系统的哥们 !!!!!!! 架构模式知多少? 请教做过基于snmp方式的入侵检测系统的哥们 !!!!!!! 请教各位大侠一个问题?? 请教做过基于snmp方式的入侵检测系统的哥们 !!!!!!! 一个初学者的麻烦! 帮忙写个求时间的函数, 请教做过基于snmp方式的入侵检测系统的哥们 !!!!!!! 二叉查找树的问题(好难啊!求救) 怎么在网页中添加一个生成EXCEL按钮 请教做过基于snmp方式的入侵检测系统的哥们 !!!!!!! 堆的一个问题?? 关于对话框的处理问题!!!!!!!!! 笔记本电脑如何进CMOS设置?我按Del不行,我想设光区启动,机子是联想的。急 Simplification 的缩写是什么? 这些繁琐的政策必须要简化(要用simplification) 高中800字作文、题目“我想要的飞翔” 单项选择,把正确的序号填在提前括号内()1.Are you ready ____ English class.A.to B.in C.me()2.____ is June first.A.Children's Day B.National Day C.Women's Day()3.The school is ____ from my house.A.long B.near C.far()4.___ magnify的意思 单项选择,将正确答案的序号填入括号里.( )1.I can play ________violin,but I can't play_______table tennis.a.the;the b./;/ c.the;/ d,/;the( )2.__________is my friend,Lucy.a.this b.these c.these d.this( )3.We carry flags and sing songs __ 为什么把鲈鱼叫大嘴鲈鱼呢? 收获父亲为什么叫我把鲈鱼放了 根据对话内容写出所缺句子,补全对话.a:Hi,Dave!1.b:They are photos a:2.b:Sure.Here are you a:Oh.They are all about animals.3.b:Yes,I like animals very much a:4.b:My favorite animals are lions a:But here are some photo of tigers.b:I want 找先行词Dan said some things about me that were not true.此句先行词是那个 苹果4S如何导入电话本?电信版的4S,智能机如何导入电话本?普通不是智能机的如何导入电话本?就是把手机卡和手机上的电话本都导入苹果手机里. 泰国沉船事故致一中国人遇难 渡轮超载苏格兰首席部长访华 推动双方经贸合作苏格兰首席部长访华 推动双方经贸合作缅甸穆斯林赴邻国避难遇海难 或死伤惨中国海外移民生存录:从\"卖猪仔\"美澳联手监听亚太 “特等舱”行动曝光印度女婴家传怪病 身体多毛酷似狼孩【深秋也会得热射病 永康男子差点没了命男子驾车时低头捡手机 一抬头开偏车道宁海男子欠前女友20万元不还 法官上曼德拉生平电影首映 前妻称反映其“苦五种不能碰的P2P局部灾害性强降雨 是诱发地灾的主因尤文客场 欲破本菲卡英菲尼迪在华加速“奔跑”电视屏幕又弯了高考506种专业,究竟落笔哪一个?不动产登记目的不是反腐和抑房价你的眼光,我的选择加女子收到神秘来信 45年前由其妹车钥匙丢不起 补回花费大耗时长“龙腾C计划”提速跑火影之注定不平凡小二上酒网游里最后一名玩家完美刺客异界寻魔路今天开始做魔女诸子门徒无限流的幻想之旅腹黑三国医杀三国金三角之王八一旅游德钦旅游武义旅游吕梁旅游文山旅游海宁旅游巫山旅游波密旅游黔西南旅游樟木旅游西陵峡风景名胜区旅游
备案号:鲁ICP备13029499号-2 说三道四 www.s3d4.cn 说三道四技术文摘