WD97: Word Count Appears InaccurateLast reviewed: February 11, 1998Article ID: Q159791 |
The information in this article applies to:
SYMPTOMSWhen you use the Microsoft Visual Basic for Applications Words property to return a word count, the number of words returned appears to be inaccurate.
CAUSEThe Words property returns a collection that represents all the words in a range, selection, or document. The collection includes all punctuation and paragraph marks in the selection or the document. For example, if you attempt to determine the word count of the following three lines of text using the Words property, the result is 21 words: This is x number of words<return> This is x number of words<return> This is x number of words<return>
WORKAROUNDTo return only the number of words in a document or a selection, exclusive of paragraph marks and punctuation, use the Dialogs object instead of the Words property. For more information about the Dialogs object, while in the Visual Basic for Applications Editor, click the Office Assistant, type "Dialogs" (without the quotation marks), click Search, and then click to view "Dialogs Object."
MORE INFORMATIONMicrosoft provides examples of Visual Basic for Applications procedures for illustration only, without warranty either expressed or implied, including, but not limited to the implied warranties of merchantability and/or fitness for a particular purpose. The Visual Basic procedures in this article are provided 'as is' and Microsoft does not guarantee that they can be used in all situations. While Microsoft support engineers can help explain the functionality of a particular macro, they will not modify these examples to provide added functionality, nor will they help you construct macros to meet your specific needs. If you have limited programming experience, you may want to consult one of the Microsoft Solution Providers. Solution Providers offer a wide range of fee-based services, including creating custom macros. For more information about Microsoft Solution Providers, call Microsoft Customer Information Service at (800) 426-9400. The Dialogs object returns a word count that does not include paragraph marks or punctuation. Using the example from the "Cause" section, the Dialogs object returns a count of 18 words. The following Visual Basic for Applications code shows the difference between using the Words property and the Dialogs object method to return a word count for a document.
Sub CountWords() 'Retrieve the number of words including paragraph marks and 'punctuation. 'This returns the same result as if you used the Word Count command '(Tools menu). Set wdDTWC = Dialogs(wdDialogToolsWordCount) wdDTWC.Execute dlgwordcount$ = wdDTWC.Words 'Retrieve the number of words from the Words collection. selwordcount$ = ActiveDocument.Words.Count MsgBox "Word Count from Tools Word Count: " & dlgwordcount$ MsgBox "Word Count from Words Collection: " & selwordcount$ End Sub |
Additional query words: word8 word97 8.0 vb vba vbe
© 1998 Microsoft Corporation. All rights reserved. Terms of Use. |