Skip to main content

Extracting the yellow highlighted text from Microsoft Word file using VBA



Function CS_ExtractHighlightedWords() As Boolean
    Dim CS_objRange As Range
    Dim CS_NewDoc_Obj As Document
    Dim CS_CollectionObj As New Collection
    
    Set CS_objRange = Application.ActiveDocument.Range
    With CS_objRange.Find
        .Highlight = True
        Do While .Execute
            If CS_objRange.HighlightColorIndex = wdYellow Then
                On Error Resume Next
                    CS_CollectionObj.Add CS_objRange.Text, CStr(CS_objRange.Text)
                    'Here we are avoiding the duplicate values to be stored in the collection using the key
                    'If any of the extracted word is being stored as duplicate key then program will through 457 error.
                On Error GoTo 0
            End If
        Loop
    End With
    
    
    On Error Resume Next
        Set CS_NewDoc_Obj = Documents.Open(FileName:="F:\log.docx", AddToRecentFiles:=False, Visible:=False)
        'Opening the new file to write the extracted words.
    On Error GoTo ErrHandler
    Dim collectionItem As Variant
    
    For Each collectionItem In CS_CollectionObj
      CS_NewDoc_Obj.Range.InsertAfter collectionItem & vbCr
      CS_objRange.Collapse 0
    Next collectionItem
    
    CS_NewDoc_Obj.Save
    CS_NewDoc_Obj.Close
    Set CS_CollectionObj = Nothing
    
    CS_ExtractHighlightedWords = True
lbl_Exit:
    Exit Function
ErrHandler:
    CS_ExtractHighlightedWords = False
    Resume lbl_Exit
End Function

Comments

Popular posts from this blog

How to Calculate HTML5 Video Height and Width dynamically to fit web page.

While developing the web pages with inline HTML5 videos we often need to adjust the video width or height according the available space on the web page.  Here is the solution to find that required height and width keeping the same aspect ratio of the video.  You may go ahead and set video CSS property to  width: 100% and height: auto but this will not give you any idea about how much height the video is going to take on the web page. Then the better approach would be setting the video height or width using Javascript. So, sometimes to adjust the width according to available height on the web page, it require to calculate the NEW WIDTH which you can set to your video as per available height. The same goes with Height as well. So here are the solutions to solve this problem. Here I am assuming the video is having 16:9 ratio, which would be a HD video with 1920px width and 1080px height. Now suppose I want my video to fit in the width of 1280px, then...

Most importment JavaScript frameworks & libraries for frontend development

Here is a list of top Most importment JavaScript frameworks & libraries for frontend development . 1. Jquery You can directly use jQuery library if your requirement is to deal with browser's DOM. jQuery has been a reliable, easy to use and handy library for frontend developers. You can trust on it's cross browser & legacy support. Along with simple jQuery.js, adding the jQuery UI provides you more features for adding different kind of interactivity on your webpage. 2. Angular Since 2016, Angular is becoming a most popular framework for clien-side development. Angular.js is the initial base of Angular (released in 2010) which was completely written in JavaScript. In 2016, Google released the next version of Angular.js as Angular 2.0 (not .js). Angular 2.0 and above versions uses Typescript as a language to write code. Angular added a new way to develop client-side SPA applications. If you want to build a Single Page Application, if you want a most secured application...

TechCS: JavaScript Part-2: How to send HTML form data with preserving line breaks in the textarea

Preserve line breaks in <textarea> while sending the HTML form data using JavaScript. Hi friends, Hope you are enjoying the time. Today I am posting a small trick about drafting mail to the given user using Javascript. Look at the following simple HTML page. The page includes user email address, subject and message body.   I have used <textarea> for getting the message body. You would be knowing that form input fields does not preserve the new line character (pressing "ENTER" button in the textarea ). Here I am writing a simple code to preserve your line break or new line character while submitting the HTML form. Look at the following code: <html> <head> <title> CS-Sending Mail preserving Line breaks in the < textarea > </title> <style>      textarea{white-space: pre-wrap;}     input{width: 250px; height: 25px; margin-top: 10px; padding: 2px;  }     .main{width: 1010...