Table Of Contents
Excel VBA Project Password
If a developer wants to hide the project's code from the other users, VBA has provided us with a tool. Using this tool, we can password protect single or multiple projects. When we right-click on a “Project,” we get an option for “VBAProject Properties.” So, for example, we can password protect the project in the protection segment.
When exposing the high-level code to the user or reader, all they have to do is to copy the code and start using it. So, it is better to protect your code with a password.
data:image/s3,"s3://crabby-images/91709/9170912871d52a21746448092d9eec5c675af1ee" alt="VBA Project Password"
How to Password Protect the VBA Project?
Like how we password protect a worksheet and workbook similarly, we can password protect the VBA codes we have written.
Follow the below steps to password protect your project.
Step 1: Create a simple Macro that needs to be protected.
Code:
Sub VBA_Project_Password() Range("A1").Value = "This is a VBA Projet Password Enabler" End Sub
data:image/s3,"s3://crabby-images/93de7/93de758a0c6a2ed3f241a22e95a648dab1241d1f" alt="VBA Project Password Example 1"
This code will insert the "This is a VBA Project Password Enabler" to cell A1. For example, assume we need to password protect this code.
Step 2: In the "Visual Basic Editor" window, click on the "Tools" tab and choose "VBAProject Properties."
data:image/s3,"s3://crabby-images/c8bf9/c8bf9337120de0fda1f7cca07fb8d0f8f19a694f" alt="VBA Project Password Example 1-1"
Step 3: This will open up the “VBAProject – Project Properties” window, which looks like the below one.
data:image/s3,"s3://crabby-images/7f84e/7f84e1caf1f0a17c787306523c4c83970deb20c6" alt="VBA Project Password Example 1-2"
Step 4: In this window, we can give a name to the project.
- We can write a description of the project.
- We can put any other arguments as well.
At the top of this window, we can see two tabs named "General" & "Protection." Choose "Protection."
data:image/s3,"s3://crabby-images/3f494/3f4948f26650fefdae405ecf5d453cf8b277401b" alt="VBA Project Password Example 1-3"
Step 5: In this "Protection," we need to enter the password we will use to protect the project. But, first, check the box "Lock project for viewing."
data:image/s3,"s3://crabby-images/4f84a/4f84a156129e8091e686485e5737bbb41b2365a9" alt="VBA Project Password Example 1-4"
Step 6: Under the "Password to view project properties" section, enter the password and confirm the password once again, then click on "OK" to close the above window.
data:image/s3,"s3://crabby-images/fd1d3/fd1d37aa1560deacb1bf2e4d7b5df57255a41ac3" alt="VBA Project Password Example 1-5"
Now, our project is password-protected. So, we need to use the password and see to view the project's properties like a module, UserForms, and codes written inside the project.
Save the workbook, close it, and reopen it.
Go to Visual Basic Editor, and we can see the below window.
data:image/s3,"s3://crabby-images/fd6f3/fd6f387bc241a78357f2663f55ff78dad686a6f1" alt="VBA Project Password Example 1-6"
Since this project is locked, we could see nothing. Click on the PLUS icon on the left-hand side.
data:image/s3,"s3://crabby-images/5c2d3/5c2d32e218c942dab0603f0a5fd231d3a9567d72" alt="Plus sign Example 1-7"
It will ask you to enter the password to see the project's properties.
data:image/s3,"s3://crabby-images/b1745/b1745578528815348c9aa81305d107d6f823eff5" alt="VBA Project Password Example 1-8"
We need to enter the password we used while protecting the project.
data:image/s3,"s3://crabby-images/a0c44/a0c44e0944f8fbeed100a5657fb1d6c679c92fb0" alt="VBA Project Password Example 1-9"
Once entering the password, click on "OK." Now, we can see the properties like worksheet names, modules, and codes.
data:image/s3,"s3://crabby-images/a27c5/a27c5a03edd58c9d0e505e5b056299f9d04266a9" alt="View code Example 1-10"
If we enter the wrong password, we will get the "Invalid password" message.
data:image/s3,"s3://crabby-images/0263e/0263ed28d80ef0b87a0fa07140883a0a706fe13b" alt="Invalid Example 1-11"
Give Password Input Box to Run the Code
If protecting the VBA project is one thing, then asking the user to enter the password to run the password is a different thing.
The below code will ask the user to enter the password to execute the code.
Code:
Sub VBA_Project_Password() Dim MyPassword As Variant Dim Password As String Password = 123 MyPassword = Application.InputBox("Enter Your Password", "Password Required to Run the Macro") If MyPassword = Password Then Range("A1").Value = "This is a VBA Project Password Enabler" Else MsgBox "Incorrect Password" End If End Sub
It will ask the user to enter the password when executed.
data:image/s3,"s3://crabby-images/c0f06/c0f0680ea232f7923fee27a1404b2efa578b1e1b" alt="required to run Example 1-12"
If the password matches, it will execute the task. Else, we will get the message below and exit the Macro.
data:image/s3,"s3://crabby-images/3a9bd/3a9bdaab79de4919299e7cc8e3db933bec57699d" alt="Incorrect Example 1-13"
Things to Remember
- It is hard to recover the document in excel without a project password, so you must be sure of your password.
- We can use third-party add-ins to break the password.