A package manager and build tool for VBA.
Prerequisites: Node.js v22 or higher.
npm install -g vbapmInstallation instructions
Windows
In powershell, run the following:
iwr https://raw.githubusercontent.com/vbapm/installer/refs/heads/main/install.ps1 | iexMac
In terminal, run the following:
curl -fsSL https://raw.githubusercontent.com/vbapm/installer/refs/heads/main/install.sh | shFor more recent versions of Office for Mac, you will need to trust access to the VBA project object model for vbapm to work correctly:
Trust access to the VBA project object model
- Open Excel
- Click "Excel" in the menu bar
- Select "Preferences" in the menu
- Click "Security" in the Preferences dialog
- Check "Trust access to the VBA project object model" in the Security dialog
If you run into any issues during installation, please see the known issues for the installer or create a new issue with details about what's happening.
🚀 You're ready to go! Open a new command-line session (cmd / terminal) and try vba --help
You can also use vbapm as a library (e.g. from a VS Code extension):
const { buildProject, loadProject, env } = require("vbapm");
// Override working directory
env.cwd = "/path/to/project";
const project = await loadProject();
await buildProject(project);Create a new folder with a blank/generated vbapm project inside
Create a folder "project-name" with a blank xlsm project:
vba new project-name.xlsm(equivalent to above)
vba new project-name --target xlsmCreate a folder "from-existing" with a project from an existing workbook:
vba new from-existing --from existing.xlsmCreate a blank package for sharing as a library between projects:
vba new json-converter --packageCreate a blank/generated vbapm project in the current folder
Create a blank xlsm project with the current folder's name:
vba init --target xlsmCreate a project from an existing workbook:
vba init --from existing.xlsmCreate a blank package:
vba init --packageBuild an Excel workbook from the project's source. The built file is located in the build/ folder and if a previously built file is found it is moved to /.backup to protect against losing any previously saved work.
Build a project:
vba buildBuild and open a project for editing:
vba build --openBuild a package using a blank target:
vba build --target xlsmBuild a project, excluding any development src, dependencies, or references:
vba build --releaseOnce you've completed your edits and are ready to commit your changes, export your project with vba export.
Export a project:
vba exportExport a previously-built package:
vba export --target xlsmvba run is a useful utility function for running a public macro in the given workbook, passing up to 10 arguments, and if it returns a string value, outputing it to the console.
' (Module: Messages.bas)
Public Function SayHi(Name As Variant) As String
SayHi = "Howdy " & Name & "!"
End Functionvba run Messages.SayHi Tim
Howdy Tim!The vbapm manifest (vbaproject.toml) serves as the foundation for your project and provides information on your package, source, dependencies, references, and targets, as detailed below.
The [package] / [project] section includes general information about your package. You should choose [package] if your project is only intended to be used as a utility inside another project and [project] if your project is a standalone tool.
Here are the main properties:
name(required)version(required for[package])authors(required for[package])target(required for[project])
Example 1
[project]
name = "awesome-excel-project"
target = "xlsm"Example 2
[package]
name = "awesome-vba-package"
authors = ["Me <me@email.com>"]
version = "0.1.0"vbapm follows Semantic Versioning. Make sure you adopt a compatible versioning approach if you intend to publish to the repository.
target is used to define what application/extension to use when building your project. It can be a string for the extension, in which case target/ includes the source files for creating the target. Otherwise, type and path can be used to define a custom target path.
Example 1:
target = "xlsm"
# equivalent to target = { type = "xlsm", path = "target" }Example 2:
target = { type = "xlam", path = "targets/xlam" }Will contain the list of source code files to be included in the VBA-Enabled Document at build time.
name = "path" or
path
[src]
A = "src/A.bas"
B = "src/B.cls"
C = { path = "src/C.bas" }name = "version" or
versionpathgit(andbranch,tag, orrev)
[dependencies]
a = "1" # Equivalent to ^1
b = "=2.0.0" # Precisely 2.0.0
c = { version = "3" }
d = { path = "./packages/d" }
e = { git = "https://..." } # master
f = { git = "https://...", branch = "dev" }
g = { git = "https://", tag = "bugfix" }
h = { git = "https://", rev = "abc1234" }version("MAJOR.MINOR")guid("{...}")
[references]
Scripting = { version = "1.0", guid = "{...}" }[dev-src], [dev-dependencies], and [dev-references] are included during development and are excluded when building with the --release flag (i.e. vba build --release)
git clonethis repo- Install Node.js v22 or later
- Note: For CLI builds, Node v23+ only supports Windows x64 (win-x64). 32-bit Windows (win-x86) is no longer available upstream.
- Install node-gyp dependencies for Mac or Windows
- Run
npm install - Run
npm run format - Run
npm run build
It will build the CLI/library inlib, plus ensured vendor node runtime is available. - Run
npm run build:addins
It will build the Excel addin that performs workbook/VBA operations from inside Office.
- Run
npm test
It will run unit tests - Run
npm run test:e2e
It will run the end-to-end CLI scenarios in excel.e2e.ts, covering workflows like build, export, new, and version against fixtures.
To keep temporary e2e work folders for manual inspection, setKEEP_E2E_TMP=1before running (PowerShell:$env:KEEP_E2E_TMP=1; npm run test:e2e, cmd:set KEEP_E2E_TMP=1 && npm run test:e2e).
To install the local version you can use the devinstall.ps1 script available in the installer submodule.
# Update submodule
git submodule update --init --recursive installer
# Run devinstall
.\installer\devinstall.ps1- Run
npm version - Run
npm run release
This project is a fork of the original vba-blocks project by Tim Hall.