ArtsAutosBooksBusinessEducationEntertainmentFamilyFashionFoodGamesGenderHealthHolidaysHomeHubPagesPersonal FinancePetsPoliticsReligionSportsTechnologyTravel

Get started with Visual Basic for Applications (VBA): an introductory tutorial

Updated on July 8, 2012

What is VBA? VBA stands for “Visual Basic for Applications”, a programming language/tool based on/in Visual Basic. One could purchase and download the full Visual Basic suite; or, to get familiar with many aspects of the language, simply access and utilize it within Microsoft Office. One of the most common ways is within Microsoft Excel. Here we will use Excel 2010.

When learning to use VBA, I found that perhaps the easiest way to get started was as follows:

First, become aware of the developer tab within Excel. The developer tab enables one to program in Visual Basic from within Excel. In order to display the developer tab, refer to this hub:

http://lucabrasi.hubpages.com/hub/How-To-Display-Developer-Tab-in-Excel-2010

Once the developer tab is activated, all the programming tabs/tools are visible. Next, open a new Excel workbook and display/activate the developer tab. See diagram 1 below.

We will be working with the circled areas:

1. Developer tab, which has been put in place and selected.

2. Record macro tab, which is traditionally used to translate a series of keystrokes into code such that it can be run whenever desired. That is the classical macro methodology: record a commonly used series of multiple keystrokes into code, so they can be run with only one keystroke. Hence, the sequence is automated. We will actually record an empty or blank macro. Why? So we have a convenient template into which we can place programming code. And, the code can then be executed from within Excel with a simple keystroke. It follows that many Excel based functions can be programmed and executed to process spreadsheet data: order it, sort it, perform calculations and graphing ……. etc.

3. Macro tab. Once we create the blank macro, this tab will be used to bring it up in edit mode. We will have a blank subroutine into which our code is placed; i.e. we can write a program.

Refer to diagram 2. Here we will create our blank macro. Hit the Record macro tab and the window will pop up. Place “a” in the shortcut key window. When we later run the program, “ctrl a” will make it run. See the macro has been given a default name “Macro1”. That can be left as is or renamed if desired. Hit the OK button, and immediately click the “stop recording” button in diagram 3. I say immediately because a macro is being recorded. It is waiting for keystrokes, for which it will enter corresponding commands. But, since we only desire to create a blank template, we hit “stop recording”.

Our blank macro has been set up. It can now be edited, in that lines of code can be placed within. Click on the Macros tab and a window for our presently blank macro will pop up. See diagram 4. Hit the Edit button, and refer to diagram 5. This is our blank macro, or code template. It is the framework for a subroutine named “Macro1”. We see the top line calling out the subroutine name, and the bottom line signifying the end of the routine. Green text contains comments for informational purposes. Anytime we start a line with the ‘ character, it is interpreted as a comment. We can comment our code in that way, so it is communicated what we were doing with each line.

Let’s write a very simple program. Refer to diagram 6. See we have entered/placed one simple line which will display a message box. Close the code window, and save the workbook under whatever name you wish. Use the “.xlsm” option, as .xlsm is for a “macro enabled workbook”. You are probably now viewing sheet1, which is fine. When you type “ctrl a”, our simple program will run as shown in diagram 7.

So we now have a way to construct a template within Excel, which can be used as a starting point for programming.

working

This website uses cookies

As a user in the EEA, your approval is needed on a few things. To provide a better website experience, hubpages.com uses cookies (and other similar technologies) and may collect, process, and share personal data. Please choose which areas of our service you consent to our doing so.

For more information on managing or withdrawing consents and how we handle data, visit our Privacy Policy at: https://corp.maven.io/privacy-policy

Show Details
Necessary
HubPages Device IDThis is used to identify particular browsers or devices when the access the service, and is used for security reasons.
LoginThis is necessary to sign in to the HubPages Service.
Google RecaptchaThis is used to prevent bots and spam. (Privacy Policy)
AkismetThis is used to detect comment spam. (Privacy Policy)
HubPages Google AnalyticsThis is used to provide data on traffic to our website, all personally identifyable data is anonymized. (Privacy Policy)
HubPages Traffic PixelThis is used to collect data on traffic to articles and other pages on our site. Unless you are signed in to a HubPages account, all personally identifiable information is anonymized.
Amazon Web ServicesThis is a cloud services platform that we used to host our service. (Privacy Policy)
CloudflareThis is a cloud CDN service that we use to efficiently deliver files required for our service to operate such as javascript, cascading style sheets, images, and videos. (Privacy Policy)
Google Hosted LibrariesJavascript software libraries such as jQuery are loaded at endpoints on the googleapis.com or gstatic.com domains, for performance and efficiency reasons. (Privacy Policy)
Features
Google Custom SearchThis is feature allows you to search the site. (Privacy Policy)
Google MapsSome articles have Google Maps embedded in them. (Privacy Policy)
Google ChartsThis is used to display charts and graphs on articles and the author center. (Privacy Policy)
Google AdSense Host APIThis service allows you to sign up for or associate a Google AdSense account with HubPages, so that you can earn money from ads on your articles. No data is shared unless you engage with this feature. (Privacy Policy)
Google YouTubeSome articles have YouTube videos embedded in them. (Privacy Policy)
VimeoSome articles have Vimeo videos embedded in them. (Privacy Policy)
PaypalThis is used for a registered author who enrolls in the HubPages Earnings program and requests to be paid via PayPal. No data is shared with Paypal unless you engage with this feature. (Privacy Policy)
Facebook LoginYou can use this to streamline signing up for, or signing in to your Hubpages account. No data is shared with Facebook unless you engage with this feature. (Privacy Policy)
MavenThis supports the Maven widget and search functionality. (Privacy Policy)
Marketing
Google AdSenseThis is an ad network. (Privacy Policy)
Google DoubleClickGoogle provides ad serving technology and runs an ad network. (Privacy Policy)
Index ExchangeThis is an ad network. (Privacy Policy)
SovrnThis is an ad network. (Privacy Policy)
Facebook AdsThis is an ad network. (Privacy Policy)
Amazon Unified Ad MarketplaceThis is an ad network. (Privacy Policy)
AppNexusThis is an ad network. (Privacy Policy)
OpenxThis is an ad network. (Privacy Policy)
Rubicon ProjectThis is an ad network. (Privacy Policy)
TripleLiftThis is an ad network. (Privacy Policy)
Say MediaWe partner with Say Media to deliver ad campaigns on our sites. (Privacy Policy)
Remarketing PixelsWe may use remarketing pixels from advertising networks such as Google AdWords, Bing Ads, and Facebook in order to advertise the HubPages Service to people that have visited our sites.
Conversion Tracking PixelsWe may use conversion tracking pixels from advertising networks such as Google AdWords, Bing Ads, and Facebook in order to identify when an advertisement has successfully resulted in the desired action, such as signing up for the HubPages Service or publishing an article on the HubPages Service.
Statistics
Author Google AnalyticsThis is used to provide traffic data and reports to the authors of articles on the HubPages Service. (Privacy Policy)
ComscoreComScore is a media measurement and analytics company providing marketing data and analytics to enterprises, media and advertising agencies, and publishers. Non-consent will result in ComScore only processing obfuscated personal data. (Privacy Policy)
Amazon Tracking PixelSome articles display amazon products as part of the Amazon Affiliate program, this pixel provides traffic statistics for those products (Privacy Policy)
ClickscoThis is a data management platform studying reader behavior (Privacy Policy)