I have been working with Excel for a while, yet i have never read what is the difference between these two operators ("regardless of i have used both")
:=
and =
in Excel VBA
2 Answers
As you already know, =
is used to assign values or set objects - e.g. i=1
:=
on the other hand (like Comintern mentioned), is used to to assign a value to a certain named argument, afaik only ever inside a method or function.
Consider the following example: you could use something like MsgBox "Hello World", , "Title1"
- specifying MsgBox
's arguments in the default order - the prompt
, the default Buttons
-style, then the Title
.
Alternatively, one could use :=
to write MsgBox Title:="Title1", prompt:="Hello world"
Notice that
the order of the arguments is of no importance here and
there is no need to specify empty placeholders for default-arguments
, ,
.
Let us take for example the Range.Find
method
expression.Find(What, After, LookIn, LookAt, SearchOrder, SearchDirection, MatchCase, MatchByte, SearchFormat)
That is a LOT of conditions to set! But you just want a simple search of the number 2
in Range("A1:A500")
:
Without the :=
operator, you would have to use commas to get to any optional variables to set:
Range("A1:A500").Find(2, , xlValue, , , , , , )
With the :=
operator, you can specify which conditions you want without delineating through all the default settings:
Range("A1:A500").Find(what:=2, lookin:=xlValues)
:=
an "operator" - it's more like a "named argument specifier". – Cominterncall function (argument:=value)
say all arguments are optional, and there are 10, you want to pass the 5th by name, then variable setting such as andlet variable=x
– Nathan_Sav