Skip to Content
Writing Word Macros, Second Edition
book

Writing Word Macros, Second Edition

by Steven Roman PhD
October 1999
Beginner
410 pages
10h 45m
English
O'Reilly Media, Inc.
Content preview from Writing Word Macros, Second Edition

Parameters and Arguments

Consider the following very simple subroutine, which does nothing more than display a message box declaring a person’s name:

	Sub DisplayName(sName As String)
	   MsgBox "My name is " & sName
	End Sub

To call this subroutine, we would write, for example:

	DisplayName "Wolfgang"

or:

	Call DisplayName("Wolfgang")

The variable sName in the procedure declaration:

	Sub DisplayName(sName As String)

is called a parameter of the procedure. In general, it must be filled in when we call the procedure (see the discussion of optional parameters coming soon). The value used in place of the parameter when we make the procedure call is called an argument. Thus, in the previous example, the argument is the string “Wolf-gang”.

Note that many programmers fail to make a distinction between a parameter and an argument, using the names interchangeably. However, since a parameter is like a variable and an argument is like a value of that variable, failing to make this distinction is like failing to distinguish between a variable and its value!

Optional Arguments

In VBA, the arguments to a procedure may be specified as optional, using the Optional keyword. (It makes no sense to say that a parameter is optional; it is assigning its value that is optional.) To illustrate, consider the procedure in Example 6-3, which simply changes the font name and font size of the current selection.

Example 6-3. Using an Optional Argument

Sub ChangeFormatting(FontName As String, Optional FontSize As Variant) ' Change ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Writing Excel Macros with VBA, 2nd Edition

Writing Excel Macros with VBA, 2nd Edition

Steven Roman PhD
101 Ready-To-Use Excel Macros

101 Ready-To-Use Excel Macros

Michael Alexander, John Walkenbach

Publisher Resources

ISBN: 9781565927254Catalog PageErrata