Microsoft Visual Basic for Applications (VBA) is a high-level programming language that allows you to write programs to automate functions and tasks within Microsoft Office. This article shows you how to secure your VBA code so that other users cannot modify or copy it.
Steps
Method 1 of 3: Password Protect the VBA Code
data:image/s3,"s3://crabby-images/fa4e5/fa4e5761bc1d9303943399b4fadb4f685cbdd615" alt="Protect VBA Code Step 1 Protect VBA Code Step 1"
Step 1. Open the Visual Basic Editor
Normally you can do this by accessing the "Tools" menu and choosing the "Macro" option (in Access, depending on your computer configuration, you may need to be inside the database window to access the editor).
-
Go to the "Tools" menu of the Visual Basic Editor and choose the "Properties" option.
Protect VBA Code Step 1Bullet1
data:image/s3,"s3://crabby-images/c8c95/c8c95f8f562e5e4d3186255ab7ec4a44fc561ec7" alt="Protect VBA Code Step 2 Protect VBA Code Step 2"
Step 2. Go to the "Security" tab
data:image/s3,"s3://crabby-images/31f61/31f61abea53c681e3c94c6cdca4088009b87a55e" alt="Protect VBA Code Step 3 Protect VBA Code Step 3"
Step 3. Select the "Lock project for viewing" check button
If you do not tick this checkbox, your code will not be hidden and protected from prying eyes.
data:image/s3,"s3://crabby-images/b04c7/b04c73fd9d47bc77e901f0477be0312e590a19c4" alt="Protect VBA Code Step 4 Protect VBA Code Step 4"
Step 4. Create a login password using the appropriate fields, then enter it again for confirmation
data:image/s3,"s3://crabby-images/433a4/433a4d18786085de2122b416e12dc5cc082c5056" alt="Protect VBA Code Step 5 Protect VBA Code Step 5"
Step 5. Save your changes and restart your program for the new settings to take effect (in Microsoft Excel 2007 and later versions, you may need to save your work in "XLSM" format for your code to work correctly)
Method 2 of 3: Hide VBA Code in Read Only Files Using Access 2007
data:image/s3,"s3://crabby-images/d4b8d/d4b8d289881583a5b6a1aa5c5130ef60f4d659b7" alt="Protect VBA Code Step 6 Protect VBA Code Step 6"
Step 1. Go to the "Database Tools" tab
data:image/s3,"s3://crabby-images/e2135/e21357621e748cc36e432ca8f4a5db27a0368932" alt="Protect VBA Code Step 7 Protect VBA Code Step 7"
Step 2. Locate the "Database Tools" group
data:image/s3,"s3://crabby-images/cd28e/cd28ef8bec74dcfe073b0b9cca8025ca7a280323" alt="Protect VBA Code Step 8 Protect VBA Code Step 8"
Step 3. Choose the "Create ACCDE" option
data:image/s3,"s3://crabby-images/a29f2/a29f2ce4fb7db086403403f5308d59995ec59a8e" alt="Protect VBA Code Step 9 Protect VBA Code Step 9"
Step 4. Save the file in "ACCDE" format using a different name from the original
The new "ACCDE" file will be created as read-only, in order to make the necessary changes to your work you will therefore need to have the original file as well.
Method 3 of 3: Protect the VBA Code By Creating an Add-on
data:image/s3,"s3://crabby-images/e2fe6/e2fe6a18a303334d3b481c7ed9ef66711dfe88c9" alt="Protect VBA Code Step 10 Protect VBA Code Step 10"
Step 1. Create an empty Office file, of the same type as the one that the VBA code will use (for example if your code works on an Excel sheet, create an empty Excel file)
data:image/s3,"s3://crabby-images/e7700/e7700805bba74599f5e233cdd667c11bb1cb470a" alt="Protect VBA Code Step 11 Protect VBA Code Step 11"
Step 2. Copy the VBA code into the Visual Basic Editor of the new file
data:image/s3,"s3://crabby-images/9091e/9091e7f7b82292fff131c0eefc981a51f6bbfa9b" alt="Protect VBA Code Step 12 Protect VBA Code Step 12"
Step 3. Open the "Macro" window, normally available in the "Tools" menu
data:image/s3,"s3://crabby-images/14b9f/14b9f81125f5d764dcb560eb313c01586ef895ec" alt="Protect VBA Code Step 13 Protect VBA Code Step 13"
Step 4. Test your code again using debug, making sure everything is working correctly
data:image/s3,"s3://crabby-images/59d66/59d660dfdf327185d8ad70becf7909a06c85f593" alt="Protect VBA Code Step 14 Protect VBA Code Step 14"
Step 5. Delete any data entered in the new file to be able to test the VBA code
data:image/s3,"s3://crabby-images/dc509/dc509602d89c26ba8eef5aad635bcf67c15d8b17" alt="Protect VBA Code Step 15 Protect VBA Code Step 15"
Step 6. Add a description to the macro that your add-on will run (you may need to select the "Options" item for your macro to be able to enter a description)
data:image/s3,"s3://crabby-images/f676a/f676ae8045270867d3af7b960a14fbd871d3322c" alt="Protect VBA Code Step 16 Protect VBA Code Step 16"
Step 7. Compile the VBA code (from the Visual Basic Editor window, access the "Debug" menu and choose the "Compile VBA project" option)
data:image/s3,"s3://crabby-images/cd5b8/cd5b8c8a16d05b411f6679a89b80d88384197184" alt="Protect VBA Code Step 17 Protect VBA Code Step 17"
Step 8. Save a copy of the file in its standard format
data:image/s3,"s3://crabby-images/e82b3/e82b318665759b6c8af6486ed5feff9eb89c483e" alt="Protect VBA Code Step 18 Protect VBA Code Step 18"
Step 9. Access the "Tools" menu of the Visual Basic Editor window and choose the "Properties" option
data:image/s3,"s3://crabby-images/4d1b5/4d1b57b758a5a5a4598558000e512a5c772a6f7a" alt="Protect VBA Code Step 19 Protect VBA Code Step 19"
Step 10. Select the "Security" tab
data:image/s3,"s3://crabby-images/28276/282762aac4c05df0010ee4ad8850b7d80627b15f" alt="Protect VBA Code Step 20 Protect VBA Code Step 20"
Step 11. Check the "Lock project for viewing" checkbox (depending on the file format you are working on and the settings of Microsoft Office and your computer, you may need to create a login password)
data:image/s3,"s3://crabby-images/bc8a3/bc8a3cd7940846881cdf5bd8cd213fd47bdb1ea2" alt="Protect VBA Code Step 21 Protect VBA Code Step 21"
Step 12. Open the "Save As" or "Save a Copy" dialog box
data:image/s3,"s3://crabby-images/bc373/bc3737f05078872a233ee6885996d7c02960ae8c" alt="Protect VBA Code Step 22 Protect VBA Code Step 22"
Step 13. Access the file format drop-down menu and choose the appropriate one for the type of add-on you created
- If you have created an add-in for Microsoft Word, use the "DOT" file format (if you want the add-in to run when Word starts, save it in your Office Startup folder).
- If you have created an add-in for Microsoft Excel, use the "XLA" file format.
- If you have created a Microsoft Access add-in, use the "MDE" file format to protect your VBA code (Microsoft Access add-ins can also be saved in "MDA" format, but in that case the VBA code will not be hidden).
- If you have created a Microsoft PowerPoint add-in, use the "PPA" file format. In this case, you will be the only user who can view and edit the VBA code.
data:image/s3,"s3://crabby-images/9c81e/9c81e14c5af554a2ab1ae0a4bec426b82b085b62" alt="Protect VBA Code Step 23 Protect VBA Code Step 23"
Step 14. Close and reopen Microsoft Office
You should now be able to use the add-on you created.
Advice
- If you can't locate the VBA Editor or Add-ons Manager, make sure it is installed on your system. Otherwise, most likely, you will need to use the Microsoft Office installation disc to proceed with adding the programs in question.
- Your Microsoft Office configuration and related settings can change where components and functions are located within each program. If you can't find a specific function, try a quick search in the "Help" using the name of the function in question.