Declaring Variables
Office 2013 and later
Contribute to this content
Use GitHub to suggest and submit changes. See our guidelines for contributing to VBA documentation.
When declaring variables, you usually use a Dim statement. A declaration statement can be placed within a procedure to create a procedurelevel variable. Or it may be placed at the
section, to create a modulelevel variable.
The following example creates the variable and specifies the String data type.
DimstrNameAsString
If this statement appears within a procedure, the variable strNamecan be used only in that procedure. If the statement appears in the Declarations section of the module, the variab
the statement appears in the Declarations section of the module, the variable strNameis available to all procedures within the module, but not to procedures in other modules in th
available to all procedures in the project, precede it with the Public statement, as in the following example:
PublicstrNameAsString
For information about naming your variables, see "Visual Basic Naming Rules" in Visual Basic Help.
Variables can be declared as one of the following data types: Boolean, Byte, Integer, Long, Currency, Single, Double, Date, String for variablelength strings, String * length
Variant. If you do not specify a data type, the Variant data type is assigned by default. You can also create a userdefined type using the Type statement. For more information on da
Visual Basic Help.
You can declare several variables in one statement. To specify a data type, you must include the data type for each variable. In the following statement, the variables intX,
type Integer.
DimintXAsInteger,intYAsInteger,intZAsInteger
In the following statement, intXand intYare declared as type Variant; only and intYare declared as type Variant; only intZis declared as type Integer.
DimintX,intY,intZAsInteger
You don't have to supply the variable's data type in the declaration statement. If you omit the data type, the variable will be of type Variant.
Using the Public Statement
You can use the Public statement to declare public modulelevel variables.
PublicstrNameAsString
Public variables can be used in any procedures in the project. If a public variable is declared in a standard module or a class module, it can also be used in any projects that referen
is declared.
Using the Private Statement
You can use the Private statement to declare private modulelevel variables.
PrivateMyNameAsString
Private variables can be used only by procedures in the same module.
Note
Note
When used at the module level, the Dim statement is equivalent to the Private statement. You might want to use the Private statement to make your code easier to read and int
Using the Static Statement
When you use the Static statement instead of a Dim statement, the declared variable will retain its value between calls.
Using the Option Explicit Statement
You can implicitly declare a variable in Visual Basic simply by using it in an assignment statement. All variables that are implicitly declared are of type Variant. Variables of type
than most other variables. Your application will be more efficient if you declare variables explicitly and with a specific data type. Explicitly declaring all variables reduces the inciden
spelling mistakes.
If you don't want Visual Basic to make implicit declarations, you can place the Option Explicit statement in a module before any procedures. This statement requires you to explici
module. If a module includes the Option Explicit statement, a compiletime error will occur when Visual Basic encounters a variable name that has not been previously declared, o
You can set an option in your Visual Basic programming environment to automatically include the Option Explicit statement in all new modules. See your application's documenta
Basic environment options. Note that this option does not change existing code you have written.
Note
You must explicitly declare fixed arrays and dynamic arrays.
Declaring an Object Variable for Automation
When you use one application to control another application's objects, you should set a reference to the other application's type library. Once you set a reference, you can declare
most specific type. For example, if you are in Microsoft Word when you set a reference to the Microsoft Excel type library, you can declare a variable of type Worksheet from withi
Microsoft Excel Worksheet object.
If you are using another application to control Microsoft Access objects, in most cases, you can declare object variables according to their most specific type. You can also use the
of an object automatically. However, you may have to indicate that it is a Microsoft Access object. For example, when you declare an object variable to represent a Microsoft Acces
Basic, you must distinguish the Microsoft Access Form object from a Visual Basic Form object. Include the name of the type library in the variable declaration, as in the following e
DimfrmOrdersAsNewAccess.Form
Some applications don't recognize individual Microsoft Access object types. Even if you set a reference to the Microsoft Access type library from these applications, you must decla
as type Object. Nor can you use the New keyword to create a new instance of the object. The following example shows how to declare a variable to represent an instance of the M
from an application that doesn't recognize Microsoft Access object types. The application then creates an instance of the Application object.
DimappAccessAsObject
SetappAccess=CreateObject("Access.Application")
To determine which syntax an application supports, see the application's documentation.
2016 Microsoft