Solved

Runtime error 5678 Word cannot find the requested bookmark

Posted on 2008-06-24
2
1,528 Views
Last Modified: 2010-04-21
Hi,
I have a Macro that is finding a value of a bookmark in the body of a document and I am then changing another value of a bookmark in the header accordingly.
This works fine while destination bookmark is in the body of the document but has the above error if I move the destination bookmark to the header.
Using a recorded macro has the same problem.
It seems even though you are in the header when you run the macro it reverts to only looking at the body.

Can anyone explain why this is? and or give me a solution to the problem.
I see this is close, but having an input box isn't what I have and I don't know the piece I need to add to my code to make it work...

http://www.experts-exchange.com/Software/Office_Productivity/Office_Suites/MS_Office/Word/Q_22960647.html

Thanks Tony
Dim lngValue As Long
 
'Selection.GoTo What:=wdGoToBookmark, Name:="RM0TotalInclGST"
    Selection.GoTo What:=wdGoToBookmark, Name:="RM0TotalInclGST"
    With ActiveDocument.Bookmarks
        .DefaultSorting = wdSortByName
        .ShowHidden = False
    End With
Selection.MoveRight Unit:=wdCharacter, Count:=2, Extend:=wdExtend
lngValue = Selection.Text
 
Selection.GoTo What:=wdGoToBookmark, Name:="INVOICETYPE"
 
If Val(lngValue) < 0 Then
Selection.Text = "CREDIT NOTE"
 
Else
Selection.Text = "TAX INVOICE"
End If
 
End Sub

Open in new window

0
Comment
Question by:Tony303
2 Comments
 
LVL 23

Accepted Solution

by:
irudyk earned 500 total points
ID: 21929295
Try the following revised code:
Dim lngValue As Long
 
'Selection.GoTo What:=wdGoToBookmark, Name:="RM0TotalInclGST"
    Selection.GoTo What:=wdGoToBookmark, Name:="RM0TotalInclGST"
    With ActiveDocument.Bookmarks
        .DefaultSorting = wdSortByName
        .ShowHidden = False
    End With
Selection.MoveRight Unit:=wdCharacter, Count:=2, Extend:=wdExtend
lngValue = Selection.Text
 
'Selection.GoTo What:=wdGoToBookmark, Name:="INVOICETYPE"
ActiveDocument.Bookmarks("INVOICETYPE").Select
 
If Val(lngValue) < 0 Then
Selection.Text = "CREDIT NOTE"
 
Else
Selection.Text = "TAX INVOICE"
End If
 
ActiveWindow.ActivePane.Close
 
End Sub

Open in new window

0
 
LVL 12

Author Closing Comment

by:Tony303
ID: 31470457
Hi,
Sorry for the long wait on this one, I guess my spam mail trapped the solution.
Anyway, great thanks, I see the secret is the
ActiveDocument.Bookmarks("INVOICETYPE").Select
and
ActiveWindow.ActivePane.Close

Thanks again

Tony
0

Featured Post

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Spacing using Word 2007 7 30
Modify table cell in winword via automation 3 38
MS Word Formatting 3 59
Need to merge 25 Word Docs into one 10 13
When creating Microsoft Word-based forms there may be a need to have a form field repeated throughout the whole document. For instance, with a company name, you may want this information repeated automatically throughout the document rather than man…
I'm writing to share my clumsy experience in using this elegant tool so you can avoid every stupid mistake I made. (I leave it to the authorities to decide if this deserves a place in the Knowledge archives.)  Now that I am on the other side of my l…
This video walks the viewer through the process of creating an MLA formatted document, as well as a bibliography with citations.
This video walks the viewer through the process of creating envelopes and labels, with multiple names and addresses. Navigate to the “Start Mail Merge” button in the Mailings tab: Follow the step-by-step process until asked to find the address doc…

803 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question