Windows API embraces VBA

The Windows Application Programming Interface (Windows API) is a set of functions from the Microsoft Windows operating system that are available to Windows programmers. Fortunately, the Windows API has always exposed a large part of the underlying structure of the Windows systems to VBA programmers.

Why VBA Programmers Need Windows API

Often times a VBA programmer may not be able find a suitable Excel or VBA function to perform a task but is available within the Windows APIs. For example, VBA does not have a function to measure time in milliseconds but it is available in Windows API (I will write another tutorial on this). In such cases, a VBA program is able access Windows APIs by declaring the Windows API function at the top of a code module.

How to declare a Windows API in VBA

A Windows API function must be declared correctly at the top of a VBA code module. The declaration statement will tell VBA 3 important pieces of information.
1. The Window API function name you’re using.
2. The Library location of the the Windows API function.
3. The Window API function’s arguments.

Here is an example:

Copy to Clipboard

Let’s try to break this down into plain English.
Declare: A Windows API declaration always start with the Declare keyword.
PtrSafe: By adding PtrSafe after the Declare keyword, it makes this API work with 64-bit Excel. If you are writing VBA code in 32-bit Excel, this keyword should not be used.
Function GetSystemDirectory Lib “kernel32”: This tells VBA that GetSystemDirectory is the name of Windows API that will be used in the VBA code and the API is located in a library called “kernel32”.
Alias “GetSystemDirectoryA”: As a VBA programmer, you can ignore this. What this means is within the kernel32 library, the Windows API actual name is  GetSystemDirectoryA.
(ByVal lpBuffer As String, ByVal nSize As Long) As Long: After calling the function, the systems directory is
contained in lpBuffer, and the length of the directory string is contained in nSize. The Windows API only returns a number indicating the length of the directory string.

Below is a VBA Sub to use this Windows API:

Copy to Clipboard

Practical Windows API Tips for the VBA Programmer

As you can see, it is essential to get the Windows API declaration exactly correct. There are many resource in the web that lists down the declarations for Windows API calls. The VBA programmer only needs to copy the declarations and use the functions without understanding the details. As a useful resource you can obtain a list of Windows API declarations for VBA by searching for this file “Win32API_PtrSafe.TXT”. Or you can download it here (don’t worry it’s a plain text file).

How to Deal with 32-bit Excel and 64-bit Excel

To ensure that a Windows API function call to work in 64-bit Excel, we need the key word “ptrSafe” somewhere in the API declaration. To ensure that an API function in both 32-bit and 64-bit Excel, we need to declare two versions of the function declaration by using conditional compiler directives.

Copy to Clipboard
Advanced Excel Training Courses Classes Singapore: Basic VBA Programming

Choose from our Most Popular Courses

Basic VBA Programming Course with Microsoft Excel. Designed for non VBA practitioners. This is a short & easy-to-follow workshop to learn how to build VBA programs from scratch in Microsoft Excel.

Consider choosing from our list of effective Microsoft Office training courses such as Excel Training Courses and PowerPoint Training Courses by Aeternus Consulting.

Useful Resource: Get Microsoft Excel for free here.