Solved

Runtime error 5678 Word cannot find the requested bookmark

Posted on 2008-06-24
2
1,537 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

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

The Selection object is designed for user interaction. It has a Range property, so it can be used in most places that a Range object can. Recorded macros must use the Selection because they are simply copying what the user is doing. A Range prope…
Introduction This tutorial provides instructions on how to properly format your Word document using the inbuilt tools provided. The benefits of using these tools means your documents are more accessible and easily portable to other applications an…
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…

839 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