Hidden named ranges

pam53154

Board Regular
Joined
Mar 3, 2009
Messages
107
I am having problems with numerous hidden named ranges being introduced to files when a tab containing those names are moved into a new file. The named ranges don't have a functional purpose and originated with files we received from a service provider. The named ranges bog down the file performance. I downloaded a name manager tool that is effective (but slow) in removing the names. However, I really need a way to prevent users from copying an "infected" tab into a new workbook in the first place so this stops spreading. Any ideas? I thought I had this wiped out previously and asked users to be mindful, but now the ranges are back anyways and I think it will continue to be that way until an actual mechanism to prevent it is put in place.
 

Excel Facts

What is the shortcut key for Format Selection?
Ctrl+1 (the number one) will open the Format dialog for whatever is selected.
Hi,

Which name manager tool do you use ?
The one written by Jan Karel Pieterse is truly great!!!

In addition, you could have a macro deleting all these named ranges...

HTH

 
Upvote 0
If there are no desired named ranges in your workbook then you can add the following code to the ThisWorkbook codepage that will delete all Named Ranges whenever any worksheet is selected:

Code:
Private Sub Workbook_SheetActivate(ByVal Sh As Object)

    Sub DeleteNamedRanges()
    
        Dim nm As Name
        
        Application.ScreenUpdating = False
        Application.EnableEvents = False
        Application.Calculation = xlCalculationManual
        
        For Each nm In ActiveWorkbook.Names
            nm.Delete
        Next
    
        Application.ScreenUpdating = True
        Application.EnableEvents = True
        Application.Calculation = xlCalculationAutomatic
    
    End Sub

End Sub
 
Upvote 0
Thanks for both comments. I am using the JKP tool. It does work great. However, as an example--the file I am "cleaning" right now has 8,353 names I need to delete. So, it takes a very long time, and there are many files like this. Unfortunately I cannot use a macro to delete all named ranges since some of the hidden ranges are needed for the file to function. For example, if I delete the hidden range called "__IntlFixup which seems to be in all files, the file will no longer open. There are also hidden named ranges for filters, print areas and data connections that cannot be deleted without significant pain to re-establish.
 
Upvote 0
I'm considering VBA code that would function something like - before the workbook is saved, check for the presence of --named range--<named range="">. If found, do not save with message box of "--named range--<named range=""> found in this workbook, please do not save until this is removed." I know enough about coding to think that is possible, but I'm not sure exactly how to do it. Thoughts?</named></named>
 
Upvote 0
This code will delete only those names in the workbook that refer to it the activeworksheet only if that worksheet name is not listed in the code.

Add this code to a standard module.

Code:
Option Explicit

Sub KillActiveWorkSheetNamesIfWorksheetIsNotExempted()

    Dim nm As Name
    Dim sName As String
    Dim bDelete As Boolean
    Dim lDeleteCount As Long
    
    If ActiveSheet.Type <> -4167 Then GoTo End_Sub 'Must be a worksheet
    
    Select Case ActiveSheet.Name
    Case "Sheet1", "Sheet3"     'Names of all worksheets that should not be deleted must be listed here in the following format:  "Sheet1", "Sheet3"
        msgbox "Names cannot be automatically deleted from this worksheet.", , "Protected Worksheet"
    Case Else
        sName = ActiveSheet.Name
    
        Application.ScreenUpdating = False
        Application.EnableEvents = False
        Application.Calculation = xlCalculationManual
    
        For Each nm In ActiveWorkbook.Names
            bDelete = False
            'Debug.Print nm.Name, nm.RefersTo
            If InStr(nm.RefersTo, "='" & sName & "'!") > 0 Then bDelete = True
            If InStr(nm.RefersTo, "=" & sName & "!") > 0 Then bDelete = True
            If bDelete Then
                nm.Delete
                lDeleteCount = lDeleteCount + 1
            End If
        Next
        
        Application.ScreenUpdating = True
        Application.EnableEvents = True
        Application.Calculation = xlCalculationAutomatic
        
        If lDeleteCount > 0 Then
            msgbox lDeleteCount & " names deleted that referred to worksheet " & sName
        End If
        
    End Select

End_Sub:

End Sub
 
Upvote 0

Forum statistics

Threads
1,225,488
Messages
6,185,282
Members
453,285
Latest member
Wullay

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top