ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 6677|回复: 23

一个关于VBPROJECT和代码的操作

[复制链接]

TA的精华主题

TA的得分主题

发表于 2006-6-12 14:05 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖已被收录到知识树中,索引项:VBE环境开发
前两天跟版上几位朋友辩论了一番,才发现这里似乎很少有VBE的对象模型编程方面的东西,做一个简单的例子 ihXRFu2m.rar (6.22 KB, 下载次数: 191) '———————————————————————————————— '几个模块的类型常量,用于区分VBComponent,可以在VBComponents.ADD时使用 '另外,在VBComponent.Type 的属性可以用来区别模块的类型 Const prjStdModule = 1 Const prjClassModule = 2 Const prjMSForm = 3 Const prjDocument = 100 Sub addMyCode() Dim prjX As Object Dim compsX As Object Dim modX As Object, clsX As Object, frmX As Object Dim strcode As String '这是要生成在标准模块的代码内容 Set prjX = Application.ActiveWorkbook.VBProject '取得工作簿的VBPROJECT对象 Set compsX = prjX.VBComponents 'VBComponenets集合,其下是各个SHEET,THISWORKBOOK,标准模块,窗体,类 Set modX = compsX.Add(prjStdModule) '增加一个标准模块 Set clsX = compsX.Add(prjClassModule) '类模块 Set frmX = compsX.Add(prjMSForm) '窗体 '在新的标准模块中增加一个HELLO子程序 strcode = "Msgbox" & Chr(34) & "hello,ExcelHome" & Chr(34) modX.codemodule.addfromstring "sub HiExcelHome() " & vbCrLf & strcode & vbCrLf & "End Sub" End Sub '————————————————————————————————————————

一个关于VBPROJECT和代码的操作

一个关于VBPROJECT和代码的操作

一个关于VBPROJECT和代码的操作

一个关于VBPROJECT和代码的操作

TA的精华主题

TA的得分主题

发表于 2006-6-12 14:21 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
嗯,谢谢分享。

TA的精华主题

TA的得分主题

发表于 2006-6-12 14:26 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2006-6-12 14:47 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2006-6-12 16:22 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2006-6-12 16:31 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2006-6-12 16:44 | 显示全部楼层
以下是引用[I]lotustower[/I]在2006-6-12 16:31:08的发言:[BR]

Programming To The VBE (English)

http://www.cpearson.com/excel/vbe.htm

谢谢lotustower提供链接,只是英文看起来有些费劲。

TA的精华主题

TA的得分主题

 楼主| 发表于 2006-6-12 17:12 | 显示全部楼层

VBE对象架构,确实不是给初学者用的

我查了一下,在古老的中文OFFICE97中,从VBPROJECT开始还有一些遮遮掩掩的帮助,能从它开始查到CODEPANE的资料

但是,在OFFICE2002就已经不行了,看到VBPROJECT,只是提了一下,这是VBPROJECT对象,来自VBE什么的,但你别想有VBPROJECT的解释

(2003XP的话就算了,那个帮助我怎么看怎么吐血,经常要上MS网的?)

这种情况下,VBAEXT对象类型库(Microsoft Visual Basic For Applications Extensibility)本身就等于是一个帮助,如果你要写什么VBE代码,光是类型常量和类结构也查得很辛苦

但是,真正写完的代码,一般还是去掉VBAEXT的引用,因为它不象其它的一些对象(ADO之类),少了类型库,不能NEW,VBE对象是隐藏起来的,类型库只是提供编码帮助(所以在主贴里,我把类型库的那几个参数提出来写成开始自定义的常量了)

TA的精华主题

TA的得分主题

发表于 2006-6-12 17:32 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

好东东, chr(34)----帮助文件中说只有1-31,

NND微软藏私.

TA的精华主题

TA的得分主题

发表于 2006-6-12 17:35 | 显示全部楼层

在VBE程式碼視窗("Code Window")功能表中新增控制項

http://vba.com.tw/VBAFILE/vbe/F0009.htm

在VBE視窗功能表中新增命令列

http://vba.com.tw/VBAFILE/vbe/F0002.htm

讓Msgbox 訊息視窗顯示在 VBE 視窗中

http://vba.com.tw/VBAFILE/vbe/F0010.htm

....

您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-12-22 16:15 , Processed in 0.044092 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表