Please Note: This article is written for users of the following Microsoft Word versions: 2007, 2010, 2013, 2016, 2019, and Word in Microsoft 365. If you are using an earlier version (Word 2003 or earlier), this tip may not work for you. For a version of this tip written specifically for earlier versions of Word, click here: Converting Strings to Numbers.
Written by Allen Wyatt (last updated January 3, 2024)
This tip applies to Word 2007, 2010, 2013, 2016, 2019, and Word in Microsoft 365
Using VBA, you can easily convert strings to numbers. You can do this with the Val() function. This function returns the value of a string, up to the first nonnumeric character. The following are examples:
A = Val(MyString) B = Val("-12345.67") C = Val("9876") D = Val(" 4 5 2 1")
The first line converts MyString into a numeric value, placing it in A. The second line results in B being set to —12345.67. The third places the value 9876 into C, and the final line sets D equal to 4521. Notice that spaces are ignored in the conversion; this is why the final line works the way it does.
You should also note that trying to use formatted numbers in a conversion will confuse the Val() function. Thus, Val("1,234") would not return a value of 1234 (as one might hope), but a value of 1. The conversion stops at the first non-numeric character, in this case the comma.
Note:
WordTips is your source for cost-effective Microsoft Word training. (Microsoft Word is the most popular word processing software in the world.) This tip (11408) applies to Microsoft Word 2007, 2010, 2013, 2016, 2019, and Word in Microsoft 365. You can find a version of this tip for the older menu interface of Word here: Converting Strings to Numbers.
Create Custom Apps with VBA! Discover how to extend the capabilities of Office 2013 (Word, Excel, PowerPoint, Outlook, and Access) with VBA programming, using it for writing macros, automating Office applications, and creating custom applications. Check out Mastering VBA for Office 2013 today!
Writing macros often involves selecting different parts of your document so that some sort of processing can be ...
Discover MoreWant to know the absolute value of a number? It's easy to derive in VBA by using the Abs function.
Discover MoreWhen creating a macro that extensively processes a document, you may need to periodically force Word to repaginate the ...
Discover MoreFREE SERVICE: Get tips like this every week in WordTips, a free productivity newsletter. Enter your address and click "Subscribe."
There are currently no comments for this tip. (Be the first to leave your comment—just use the simple form above!)
Got a version of Word that uses the ribbon interface (Word 2007 or later)? This site is for you! If you use an earlier version of Word, visit our WordTips site focusing on the menu interface.
Visit the WordTips channel on YouTube
FREE SERVICE: Get tips like this every week in WordTips, a free productivity newsletter. Enter your address and click "Subscribe."
Copyright © 2024 Sharon Parq Associates, Inc.
Comments