VBA 必备知识及注意点

本人主要是从事Android,iOS及JAVA web后台开发,所以本篇文章主要说的是有java编程语言基础后,书写VBA经常会犯的几个错误以及本人在写VBA工具中的几个思路,代码中斜线内容就是特别注意的地方。

1.条件语句:

java中:

if () {

} else if() {

} else {

}

VBA中:

If () then

Elseif () then

Else

End If

2.循环

VBA的写法是

for   i = 1 to 10 step 1

End for

注意:VBA主要是做单元格的循环,是从1开始的!!!如果需要修改每次加的值只需要修改step就行

3.自定义方法

VBA中有两种,一种是sub,一种是function,这两者最大的区别就是有没有返回值,如果需要返回值,一定要用function;如果不需要,两者都可以,本人习惯用sub。如果需要给按钮指定宏的话,是只能指定sub,不能指定function的。

Function test(ByVal temp As String) As String

          test = temp

End Function

(1)函数的返回值是使用函数名直接赋值得来的,相当于java中的 return temp;

(2)形参有两种一种是ByVal,一种是ByRef,ByVal是值传递,也就是说一个数值传入之后,在函数中无论做什么操作,也不会修改传入参数本身,ByRef是址传入,如果函数中修改了形参的值,那么传入参数的值就改变了。这个可以参考C语言的指针中的值传递和址传递的区别。一般都是ByVal

4.赋值

Dim  test As   Integer

test = 5

值类型直接如上所示赋值即可,实际上VBA真正处理时是使用了let语句

let    test = 5

那么在处理对象中,VBA是需要使用set语句的,但是我们会经常忘记加上set,导致报错

"运行时错误g1,未设置对象变量或With块变量"

Dim     testRange     as Range

set    testRange =  Range("A1")

5.变量的命名

其他语言:以英文字母或下划线开头,后面可以使用英文字母,下划线及数字

VBA:以英文字母开头,后面可以使用英文字母,下划线,数字及汉字

6.代码书写的位置

VBA的代码可以写在worksheet,workbook,module中,建议方法写在module,然后在worksheet和workbook的按钮事件和worksheet,workbook的事件中调用module中的方法。

好处:sheet页删除后,实现方法仍在module中,只需要新建sheet页,添加按钮去调用就可以用。

后续会写一篇VBA技巧的文章,提供禁止用户修改sheet页名,禁止删除sheet页的小技巧。

7.VBA代码扩展性

一个是工具页,一个是工具配置页,module中代码采用自定类型参数,工具页中代码只负责读取工具配置页中单元格相应的值,生成自定义参数,然后调用module中的代码。之前写个工具花费1天,整改了两次代码,最后又花费了2天,将心得体会分享出来,希望对看文章的你有所帮助。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容

  • 本例为设置密码窗口 (1) If Application.InputBox(“请输入密码:”) = 1234 Th...
    浮浮尘尘阅读 13,641评论 1 20
  • 1.1 VBA是什么 直到90年代早期,使应用程序自动化还是充满挑战性的领域.对每个需要自动化的应用程序,人们不得...
    浮浮尘尘阅读 21,737评论 6 49
  • 使用首先需要了解他的工作原理 1.POI结构与常用类 (1)创建Workbook和Sheet (2)创建单元格 (...
    长城ol阅读 8,422评论 2 25
  • 最近在网上爬取奥运项目资料,并写入Excel中。在写到Excel中是用到了OpenPyXL,翻译了一部分自己用到的...
    LeeLom阅读 199,764评论 7 78
  • 刚到小区,车被老婆小玉儿的朋友拦住了。降下车窗,朋友说,妮子妈,今天晚上说好了啊。东来顺涮锅。 这位朋友要请客,缘...
    山顶的声音阅读 520评论 6 2