概要

学习一种新语言, 数据类型和关键字是第一步.

数据类型

常用的数据类型如下:

类型 存储空间 范围
Boolean 2 bytes True 或者 False
Byte 1 byte 0 ~ 255
Integer 2 bytes -32768 ~ 32768
Long 4 bytes -2147483648 ~ 2147483647
LongLong 8 bytes -2147483648 ~ 2147483647
String 10 bytes + string length 0 ~ 20 亿个字符
Object 4 bytes 可以赋值给任何对象引用
Single 4 bytes -3.402823E38 ~ -1.401298E-45 (对负值)
1.401298E-45 ~ 3.402823E38 (对正值)
Double 8 bytes -1.79769313486231E308 ~ -4.94065645841247E-324 (对负值)
4.94065645841247E-324 ~ 1.79769313486231E308 (对负值)
Date 8 bytes 100 年 1 月 1 日 ~ 9999 年 12 月 31 日 0:00:00 ~ 23:59:59
Variant 16 bytes 任意值, 性能较低

VBA 中提供了一系列 函数用于类型之间的转换

运算符

运算符是和数据类型同样, 是使用最多的部分.

类型 运算符 说明 示例
算术运算符 * 乘法 MyValue = 2 * 2 ' Returns 4.
^ 乘方 MyValue = 2 ^ 2 ' Returns 4.
/ 除法运算, 返回浮点型结果 MyValue = 10 / 4 ' Returns 2.5.
\ 除法运算, 返回整数结果 MyValue = 100 \ 3 ' Returns 33.
Mod 求余数 MyResult = 10 Mod 3 ' Returns 1.
+ 加法 MyNumber = 2 + 2 ' Returns 4.
- 减法 MyResult = 4 - 2 ' Returns 2.
比较运算符 = 判断是否相等 Check = (4 = 4) ' Returns True
Is 判断 2 个对象的引用是否相同 Set ThisObject = MyObject
MyCheck = ThisObject Is ThisObject ' Returns True.
Like 比较字符串时, 可以使用通配符, 简化版的正则 MyCheck = "aBBBa" Like "a*a" ' Returns True.
连接运算符 & 连接字符串 MyStr = "Hello" & " World" ' Returns "Hello World".
+ 除了作为加法, 还可以用在字符串上 Var1 = "34": Var2 = 6; MyNumber = Var1 + Var2 ' Returns 40.
Var1 = "34": Var2 = "6"; MyNumber = Var1 + Var2 ' Returns "346".
逻辑运算符 And 逻辑与
Eqv 逻辑等于
Imp 不太常用 imp-operator
Not 逻辑非
Or 逻辑或
Xor 逻辑异或

变量

有了数据类型, 就可以定义各种变量, 完成相应的计算. 变量的定义和计算, 和其他编程语言也没有什么区别, 这里主要提下变量的生命周期.

全局变量和局部变量

 1  Dim globalX As Integer
2
3 Sub Test()
4 f1
5 globalX = globalX + 1
6 localX = localX + 1
7 f1
8 End Sub
9
10 Function f1()
11 Dim localX As Integer
12
13 Debug.Print "全局变量 " & globalX
14 Debug.Print "局部变量 " & localX
15 End Function

运行 Test, 输出:

   全局变量  0
局部变量 0
全局变量 1
局部变量 0

静态变量和动态变量

 1  Sub Test()
2 f1
3 f1
4 f1
5 End Sub
6
7 Function f1()
8 Dim dX As Integer
9 Static sX As Integer
10
11 sX = sX + 1
12 dX = dX + 1
13 Debug.Print "静态变量 " & sX
14 Debug.Print "动态变量 " & dX
15 End Function

运行 Test, 输出:

   静态变量  1
动态变量 1
静态变量 2
动态变量 1
静态变量 3
动态变量 1

VBA基础 - 数据类型的更多相关文章

  1. Office·Word高级·VBA基础概念语法

    阅文时长 | 5.21分钟 字数统计 | 1823字符 『Office·Word高级·VBA基础概念语法』 编写人 | SCscHero 编写时间 | Monday, June 29, 2020 文章 ...

  2. [.net 面向对象编程基础] (3) 基础中的基础——数据类型

    [.net 面向对象编程基础] (3) 基础中的基础——数据类型 关于数据类型,这是基础中的基础. 基础..基础..基础.基本功必须要扎实. 首先,从使用电脑开始,再到编程,电脑要存储数据,就要按类型 ...

  3. TypeScript学习指南第一章--基础数据类型(Basic Types)

    基础数据类型(Basic Types) 为了搭建应用程序,我们需要使用一些基础数据类型比如:numbers,strings,structures,boolean等等. 在TypeScript中除了Ja ...

  4. VBA基础——循环语句

    VBA基础之循环语句 Sub s1() Dim rg As Range For Each rg In Range("a1:b7,d5:e9") If rg = "&quo ...

  5. 【Swift】学习笔记(一)——熟知 基础数据类型,编码风格,元组,主张

    自从苹果宣布swift之后,我一直想了解,他一直没有能够把它的正式学习,从今天开始,我会用我的博客来驱动swift得知,据我们了解还快. 1.定义变量和常量 var  定义变量,let定义常量. 比如 ...

  6. 二、Windows基础数据类型

    六.Windows Data Types 简介: 6.1.这些数据类型都是C语言数据类型的再次的进行包装. 6.2.因为考虑到如果使用的是C中的基础数据类型可能无法表示,想表示的精准的含义. 6.3. ...

  7. java基础数据类型包装类

    */ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...

  8. java.lang基础数据类型boolean、char、byte、short、int、long、float、double (JDK1.8)

    java.lang.Boolean public static int hashCode(boolean value) { return value ? 1231 : 1237; } JDK 1.8新 ...

  9. Python基础数据类型之列表和元组

    一.列表   list 列表是python中的基础数据类型之一,其他语言中也有类似于列表的数据类型,比如js中叫数组,他是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如: li ...

随机推荐

  1. javascript中优雅的处理async和await异常

    let handler = async function(needErr) { return new Promise((resolve, reject) => { if (needErr) { ...

  2. React: React的组件状态机制

    一.简介 在React中,有两个核心的默认属性,分别是state和props.state会记录组件的状态,React根据状态的变化,会对界面做相应的调整或渲染.props则是数据流向属性,React通 ...

  3. jieba 分词使用入门

    1. 介绍 JIEBA 是目前最好的 Python 中文分词组件,它主要有以下 3 种特性: 支持 3 种分词模式:精确模式.全模式.搜索引擎模式 支持繁体分词 支持自定义词典 import jieb ...

  4. route 相关设置

    Debian系统 查看路由表: root@debian:~# ip route default via 192.168.6.1 dev enp4s0 10.0.0.0/24 dev br0 proto ...

  5. node.js如何批量赋值

    1. 数组解析赋值 let a = 1; let b = 2; let c = 3; 等同于 let [a, b, c] = [1, 2, 3]; 默认值 let [a, b = "B&qu ...

  6. C#上手练习1(if语句、Swich语句)

    1.打印字符串. 2.调用简单方法,方法里有if语句.Swich语句. C# if else 语句是最常用的条件语句,并且 if else 语句的形式有多种,包括单一条件的 if 语句.二选一条件的 ...

  7. Docker开启Remote API 访问 2375端口

    Docker常见端口 我看到的常见docker端口包括: 2375:未加密的docker socket,远程root无密码访问主机2376:tls加密套接字,很可能这是您的CI服务器4243端口作为h ...

  8. CSS符合选择器

    CSS复合选择器 后代选择器 后代选择器又称为包含选择器,可以选择父元素里面的子元素.其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔,当标签发生嵌套时,内层标签就成为外层标签的后代 元 ...

  9. 协议分析中的TCP/IP网络协议

    - 链路层 第一层包含源mac及目的mac,随着传输路径的变化会发生变化,在mac之后,是下层网络协议的类型,图中,下层为IP协议. 在协议解析中,需要关注的是图中type这个字段的内容. - 网络层 ...

  10. Swift 字典模型互转总结

    现在很多iOS项目的开发开始转向Swift语言. 相信 Swift语言很快会成为iOS工程师 必备技能. 字典转模型, 模型转转字典在开发过程中扮演非常重要的角色. 今天就和大家分享一下使用Swift ...