一文快入VBA——一个VBA数据处理小程序的解析

这是我自己写的一个VBA处理的小程序,它极大地帮助我提高了数据处理的速度,现在我把它分享给你。个人觉得如果能够看看该程序,ExcelVBA使用的基本问题就不是比较大了。现在我们来归纳下程序中使用到的ExcelVBA技能点。

程序的定义,VBA程序的定义以Sub开头,以End Sub结尾,方法名加括号,不区分大小写。

结果的输出,程序的输出方式是Debug.Print,这是一种非常实用的输出函数,比Msgbox要方便的多,也是VBA调试程序必备的。

区域的选择及地址的格式,在VBA的写作过程中,经常不能够将程序写死,需要保留一定的灵活性,因此再用Selection.Address就可以动态地告诉程序,从而给出较大的变动余地。在地址的获取过程中,如果不对其进行界定,优先获取绝对地址,不如要使用相对地址,需要添加参数,如例中所示。

变量的定义,VBA中可以使用未定义的变量,但是推荐对其进行预先定义,定义的方法是Dim加变量名加As加变量类,比如在示例里面,将currentCell界定为Range。

循环的方法,一般而言,循环的方法主要有while,for两大类,在本例中使用的For Each能够更好地遍历区域内的每一个单元格,是一种比较简单省事的循环方法。

调用子程序的方法,因为是子方法,所以需要使用到Call。

条件语句,VBA的标准套路是If…Then …End If。如果中间需要添加别的,直接就是Else If。

数组的使用和循环。VBA提供数组动态变动的方法,因此在变量的时候,无需对长度进行定义,比如Dim string0。VBA的循环采用的UBound和LBound两个函数的组合来对区间进行确定,相比其他语言而言,个人觉得相对累赘了点。

单元格区域的定位方法。单元格的定位函数是非常重要的,一般来说,Cells和Offset是比较常用的,因为Excel中绝对位置发生不一致,因此Offset是一定相对定位的方法,意思即为向行和列分别一定多少。

字符串操作函数,字符串的操作是无比重要的,比如在本例中,使用了Split函数来分割字符串,形成字符串数组。

数字操作函数,Sgn是一个非常有用的函数,它会告诉你数据的正负号,在数据操作中,非常有用。

本文来自企鹅号 - 无所不能的Excel媒体

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Nian糕的私人厨房

JavaScript 基础

JavaScript 是一种轻量级,解释型的,有着函数优先 (First-class Function) 的编程语言,虽然它是作为开发 WEB 页面的脚本语言而...

12750
来自专栏我的小碗汤

go语言正则表达式

我们前两节课爬取珍爱网的时候,用到了很多正则表达式去匹配城市列表、城市、用户信息,其实除了正则表达式去匹配,还可以利用goquery和xpath第三方库匹配有用...

13940
来自专栏LIN_ZONE

javascript基础重点

1.在javascript中使用 == 比较,会自动转换数据类型再比较,有时候会 得到非常诡异的结果;一般情况下使用 === 比较,它不会自动转换数据类型,如果...

9620
来自专栏流浪猫的golang

go rune 简要分析

今天看golang代码看到一个单词 rune ,熟悉而陌生。之前学习go并没有过多注意这个“神秘符号”。 rune在golang中是int32的别名,在各个...

8810
来自专栏landv

Golang 新手可能会踩的 50 个坑【转】

译文:https://github.com/wuYin/blog/blob/master/50-shades-of-golang-traps-gotchas-m...

38120
来自专栏Golang语言社区

Golang语言--一些基础用法

range类似迭代器操作,返回 (索引, 值) 或 (键, 值)。其可以使用的对象包括string,array/slice,map,channel。其中stri...

34970
来自专栏张善友的专栏

深入浅出事件流处理NEsper(二)

NEsper使用的事件类型来描述事件的类型信息。你的应用在启动时可能预先配置定义事件类型,或者在运行时通过API或EPL语法动态的增加事件类型。 EPL中的cr...

202100
来自专栏IMWeb前端团队

20个例子入门Q.js

本文希望通过20个简单的例子让没用过Q.js的同学快速掌握其基本用法 1. 新建实例 html代码: <div id="demo" q-text="msg"><...

31270
来自专栏LEo的网络日志

go语言接口学习

37250
来自专栏乐百川的学习频道

Golang学习笔记 控制流

条件语句 if语句 下面是Golang的if语句,需要注意的是条件判断块不需要小括号,而且if语句的大括号不能省略,即使其中只有一行语句。 if conditi...

20650

扫码关注云+社区

领取腾讯云代金券