Skip to Content
Writing Word Macros, Second Edition
book

Writing Word Macros, Second Edition

by Steven Roman PhD
October 1999
Beginner
410 pages
10h 45m
English
O'Reilly Media, Inc.
Content preview from Writing Word Macros, Second Edition

Example: Finding Used Styles

As discussed earlier, Word considers a custom style to be in use even if no current text is formatted with that style. However, whenever I turn in a manuscript for a book, the production editors always want a list of all of the paragraph styles that I really used in that manuscript. They don’t care about styles that I might have used and then removed.

There are actually a couple of ways you could create such a list. One way would be to start with a list of all InUse styles. Then you could go through the document looking at the styles of each paragraph, checking off those styles on your list. However, there may be several thousand paragraphs in a document, and you would have to search the style list each time. This might be a bit slow.

Alternatively, you could cycle through the document, recording the style of each paragraph in a string array. Then you would need to eliminate the duplicates, which is most efficiently done if the array is sorted. The code in Example 12-7 (which lists only paragraph styles) takes this approach. It provides a good example of manipulating arrays.

Example 12-7. Finding Used Styles in a Document

Sub FindUsedStyles() Dim sAllStyles() As String Dim sUsedStyles() As String Dim i As Long Dim idx As Long Dim cParas As Long Dim cUsedStyles As Long Dim sPrevStyle As String Dim para As Paragraph ' Count of paragraphs in document cParas = ActiveDocument.Paragraphs.Count ' Redim array to correct size ReDim sAllStyles(1 To cParas) ' Collect ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.

Read now

Unlock full access

More than 5,000 organizations count on O’Reilly

AirBnbBlueOriginElectronic ArtsHomeDepotNasdaqRakutenTata Consultancy Services

QuotationMarkO’Reilly covers everything we've got, with content to help us build a world-class technology community, upgrade the capabilities and competencies of our teams, and improve overall team performance as well as their engagement.
Julian F.
Head of Cybersecurity
QuotationMarkI wanted to learn C and C++, but it didn't click for me until I picked up an O'Reilly book. When I went on the O’Reilly platform, I was astonished to find all the books there, plus live events and sandboxes so you could play around with the technology.
Addison B.
Field Engineer
QuotationMarkI’ve been on the O’Reilly platform for more than eight years. I use a couple of learning platforms, but I'm on O'Reilly more than anybody else. When you're there, you start learning. I'm never disappointed.
Amir M.
Data Platform Tech Lead
QuotationMarkI'm always learning. So when I got on to O'Reilly, I was like a kid in a candy store. There are playlists. There are answers. There's on-demand training. It's worth its weight in gold, in terms of what it allows me to do.
Mark W.
Embedded Software Engineer

You might also like

Writing Excel Macros with VBA, 2nd Edition

Writing Excel Macros with VBA, 2nd Edition

Steven Roman PhD
101 Ready-To-Use Excel Macros

101 Ready-To-Use Excel Macros

Michael Alexander, John Walkenbach

Publisher Resources

ISBN: 9781565927254Catalog PageErrata