Удалить скрытые имена в excel макрос

Excel для Microsoft 365 Excel 2021 Excel 2019 Excel 2016 Excel 2013 Excel 2010 Еще…Меньше

Инспектор документов обнаружил в книге скрытые имена. Под этими именами может храниться скрытая информация о сценариях надстройки «Поиск решения». Например, если вы используете надстройку «Поиск решения» для выполнения сценария, в ней может храниться информация о параметрах расчета и других конфиденциальных данных, например скрытые имена в книге.

Важно: Корпорация Майкрософт предоставляет примеры программирования только для иллюстрации без гарантии, выраженной или подразумеваемой. Это относится и не только к подразумеваемой гарантии пригодности и пригодности для определенной цели. В этой статье предполагается, что вы знакомы с языком программирования, который демонстрируется, и средствами, используемыми для создания и от debug procedures. Специалисты службы поддержки Майкрософт могут объяснить функциональные возможности конкретной процедуры, но не будут изменять эти примеры, чтобы предоставить дополнительные функции или процедуры по построению с учетом ваших конкретных требований.

Проблема

Инспектор документов не может удалить эти имена.

Рекомендуемое решение

Чтобы удалить скрытые имена, запустите следующий макрос: В макросе отображается окно сообщения с тремя элементами: (1), видимым или скрытым, (2) определенным и (3) ссылкой на это имя (ссылка на ячейку книги). Чтобы удалить или сохранить каждое определенное имя, выберите вариант Да или Нет.

Примечание: После удаления скрытых имен с помощью этого макроса надстройки (например, «Поиск решения») и макросы могут работать неправильно, и связанные с ними скрытые данные могут быть потеряны. Этот макрос действует на все имена, которые определяются как скрытые, а не только на те, которые были добавлены надстройкой «Поиск решения».

Внимание: Если имена листов содержат пробелы, при попытке удалить определенное имя может появиться сообщение об ошибке.

Удаление скрытых имен

' Module to remove all hidden names on active workbook
   Sub Remove_Hidden_Names()

       ' Dimension variables.
       Dim xName As Variant
       Dim Result As Variant
       Dim Vis As Variant

       ' Loop once for each name in the workbook.
       For Each xName In ActiveWorkbook.Names

           'If a name is not visible (it is hidden)...
           If xName.Visible = True Then
               Vis = "Visible"
           Else
               Vis = "Hidden"
           End If

           ' ...ask whether or not to delete the name.
           Result = MsgBox(prompt:="Delete " & Vis & " Name " & _
               Chr(10) & xName.Name & "?" & Chr(10) & _
               "Which refers to: " & Chr(10) & xName.RefersTo, _
               Buttons:=vbYesNo)

           ' If the result is true, then delete the name.
           If Result = vbYes Then xName.Delete

           ' Loop to the next name.
       Next xName

   End Sub

Нужна дополнительная помощь?

Здравствуйте. Рад представить Вам пошаговую инструкцию по удалению скрытых имен в Экселе. Вы возможно сталкивались с ситуацией, когда при копировании листа в книге Excel возникала ошибка, которая сообщает что Имя уже существует и нужно либо выбрать новое, либо использовать тоже. Хорошо если таких ошибок 2 — 3, а если их несколько сотен или тысяч, тогда никакого терпения не хватит нажимать ОК. Используя рекомендации, представленные ниже, Вы избавитесь от ошибки навсегда! Итак, приступим:

1. Создание макроса DeleteHiddenNames.

Встроенной функции в Excel для решения этой проблемы я не нашел, зато есть замечательный макрос, с помощью которого мы от нее избавимся. Сначало надо зайти в редактор макросов, для этого запустите Excel, откройте файл с проблемой и нажмите ALT+F11. Откроется Microsoft Visual Basic for Applications, далее заходим в меню Insert и выбираем Module.

Как удалить скрытые имена в Excel

Открывается окно модуля. Туда Вы должны вставить следующий код макроса:

Sub DeleteHiddenNames()
Dim n As Name
Dim Count As Integer
On Error Resume Next
For Each n In ActiveWorkbook.Names
    If Not n.Visible Then
    n.Delete
    Count = Count + 1
    End If
Next n
MsgBox «Скрытые имена в количестве » & Count & » удалены»
End Sub

Выглядеть это должно в результате следующим образом:

Как удалить скрытые имена в Excel

Отлично. Макрос мы создали, теперь нам осталось его применить.

2. Использования макроса для удаления скрытых имен в Excel.

Переключаемся назад на нашу Эксель книгу, переходим в меню Вид, там выбираем блок Макросы и в нем нажимаем на меню Макросы.

Как удалить скрытые имена в Excel

 В открывшемся меню выбираем макрос DeleteHiddenNames и нажимаем кнопку выполнить.

Как удалить скрытые имена в Excel

Макрос отработает некоторое время (чем больше скрытых имен у Вас в файле, тем дольше он будет работать) и выдаст сообщение о том, сколько имен было удалено. Поздравляю Вы избавились от проблемы и можете смело копировать листы.

Как удалить скрытые имена в Excel

Я надеюсь что эта инструкция Вам помогла, заходите на сайт почаще — здесь много еще чего полезного для Эксель найдете. Есть вопросы — смело пишите их в комментариях к статье.

На работе мне приходится заполнять эксель-файл с индивидуальными целевыми показателями (используется для расчета премии). Шаблоны файлов поступили из центрального офиса. Ежемесячно я копирую последнюю вкладку и заполняю актуальной информацией. 

Всё бы ничего, но каждый раз при копировании выскакивает окно с уведомлением о том, что копируемые формулы содержат какие-то имена. И таких имён порядка 30 на странице. То есть, каждый раз копируя вкладку мне надо 30 раз нажать кнопку «Да».

Когда это случилось первый раз я просмотрел все ячейки, никаких имён не нашёл и… махнул на это рукой. Месяц спустя, когда снова копировал вкладку — выругался, 30 раз подтвердил и снова забыл на месяц. В общем, так прошло больше года. Однако, даже моё терпение заканчивается…

Вчера, в очередной раз столкнувшись с необходимостью нажимать кнопку «Да», залез в Гугл с запросом «удалить имена в эксель». Нашёл замечательную страничку, где прочитал, как можно просмотреть список имен (нажав кнопку «Все имена» в диалоговом окне, вызываемом из меню Вставка — Имя — Вставить…) и удалить ненужные

Сделал, удалил, но… диспетчер имён удаляет только видимые имена, а есть ещё и скрытые. 

Следующая ссылка привела на сайт Майкрософт (доступ только по учётной записи). Там выложен макрос, который позволяет удалять скрытые имена из эксель-файла. Копирую макрос здесь, чтобы на будущее не искать:

‘ Module to remove all hidden names on active workbook
Sub Remove_Hidden_Names()
‘ Dimension variables.
Dim xName As Variant
Dim Result As Variant
Dim Vis As Variant
‘ Loop once for each name in the workbook.
For Each xName In ActiveWorkbook.Names
‘If a name is not visible (it is hidden)…
If xName.Visible = True Then
Vis = «Visible»
Else
Vis = «Hidden»
End If
‘ …ask whether or not to delete the name.
Result = MsgBox(prompt:=»Delete » & Vis & » Name » & _
Chr(10) & xName.Name & «?» & Chr(10) & _
«Which refers to: » & Chr(10) & xName.RefersTo, _
Buttons:=vbYesNo)
‘ If the result is true, then delete the name.
If Result = vbYes Then xName.Delete
‘ Loop to the next name.
Next xName
End Sub

Вот вся последовательность необходимых действий:

На вкладке «Вид» (1) нажимаем кнопку «Макросы» (2) — выскакивает окно. Вводим произвольное имя (3) — становится доступной кнопка «Создать» (4). Нажимаем…

Открывается окно редактора макросов с набранными несколькими строчками заготовки макроса (5). 

Копируем код макроса на место имеющегося текста и закрываем окно текущего макроса (6) и окно редактора макросов.

Снова Вид — Макросы и видим, что произвольное имя изменилось на Remove_Hidden_Names. Выбираем и нажимаем «Выполнить» (7)

Макрос запрашивает подтверждение на удаление каждого из имен, но это в последний раз. Так как кнопка «Yes» активна по умолчанию и если ни одно имя не нужно, то можно просто нажать и держать «Enter», пока все имена не будут удалены.

Всё. Теперь вкладку можно копировать без каких-либо дополнительных подтверждений.

Удалить все кроме нужных именованные диапазоны

Anis625

Дата: Четверг, 01.04.2021, 16:23 |
Сообщение № 1

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Добрый день, всем участникам форума!
Прошу оказать содействие в правки моего кода «Франкенштейна»:
[vba]

Код

Sub DeleteExternalNames()
‘отображаем скрытые имена
Dim nName As Name
For Each nName In ActiveWorkbook.Names
   nName.Visible = True
Next nName
‘удаляем лишние имена
Dim n As Name
For Each n In Application.ActiveWorkbook.Names
    n.Delete
count = count + 1
Next n
MsgBox «Все имена в количестве » & count & » удалены»
End Sub

[/vba]
Этим кодом отображаю все скрытые имена и потом удаляю все именованные диапазона (т.к. при копировании листа всем известно что происходит с тысячами имен).
Но в некоторых файлах есть нужные именованные диапазоны (списки, умные таблицы, созданные в этой книге).
Попытался удалить только имена с ошибками:
[vba]

Код

For Each IName In ActiveWorkbook.Names
    If IName.RefersTo Like «*REF!*» Then
    IName.Delete ‘удаление имени с ошибками
    End If
Next

[/vba]
Но остаются имена с внешними ссылками или системными (которые подтянулись из файлов 1С).
На одном из сайте нашел что можно сделать «Если n.referestorange существует, и если n.referstorange.worksheet.parent is thisworkbook, то не удалять», но не понял как это вкрутить в свой код.
Буду признателен за любой совет.

 

Ответить

Anis625

Дата: Четверг, 01.04.2021, 16:33 |
Сообщение № 2

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Пустой файл с лишними именованными диапазонами весит почти метр. Сделал архив из двух файлов

 

Ответить

Pelena

Дата: Четверг, 01.04.2021, 18:49 |
Сообщение № 3

Группа: Админы

Ранг: Местный житель

Сообщений: 18797


Репутация:

4284

±

Замечаний:
±


Excel 2016 & Mac Excel

Попробуйте такой вариант, только сначала на копии файла)
[vba]

Код

Sub DeleteExternalNames()
‘отображаем скрытые имена
    Dim nName As Name
    For Each nName In ThisWorkbook.Names
        nName.Visible = True
    Next nName
    ‘удаляем лишние имена
    Dim n As Name, count As Long
    On Error Resume Next
    For Each n In ThisWorkbook.Names
        If InStr(n.RefersTo, «#») > 0 Or InStr(n.RefersTo, «\») > 0 Then
            n.Delete
            count = count + 1
        ElseIf Not n.RefersToRange.Worksheet.Parent Is ThisWorkbook Then
            n.Delete
            count = count + 1
        End If
    Next n
    MsgBox «Все имена в количестве » & count & » удалены»
End Sub

[/vba]


«Черт возьми, Холмс! Но как??!!»
Ю-money 41001765434816

 

Ответить

Anis625

Дата: Четверг, 01.04.2021, 20:16 |
Сообщение № 4

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Pelena,
Даже с решением. Спасибо Вам, попробую

 

Ответить

Anis625

Дата: Четверг, 01.04.2021, 21:30 |
Сообщение № 5

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Pelena,
Не срабатывает код. Буквально сразу после запуска выводится сообщение msgbox «Все имена в количестве 0 удалены»
Получается сразу отрабатывается строка[vba][/vba]

Сообщение отредактировал Anis625Четверг, 01.04.2021, 21:47

 

Ответить

Pelena

Дата: Четверг, 01.04.2021, 22:05 |
Сообщение № 6

Группа: Админы

Ранг: Местный житель

Сообщений: 18797


Репутация:

4284

±

Замечаний:
±


Excel 2016 & Mac Excel

Вот, что стало с Вашим файлом-примером, которыйпосле работы макроса. Как видите размер резко уменьшился

К сообщению приложен файл:

__—.xlsm
(27.4 Kb)


«Черт возьми, Холмс! Но как??!!»
Ю-money 41001765434816

 

Ответить

Anis625

Дата: Четверг, 01.04.2021, 22:26 |
Сообщение № 7

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Pelena,
Странное дело — поместил код в «Личную книгу макросов» не работает. Поместил в модуль книги — работает. Из-за чего может быть так?
На счет размера — согласен, что в этом и была причина такого веса, поэтому и пытался решить задачку.

 

Ответить

Pelena

Дата: Четверг, 01.04.2021, 22:32 |
Сообщение № 8

Группа: Админы

Ранг: Местный житель

Сообщений: 18797


Репутация:

4284

±

Замечаний:
±


Excel 2016 & Mac Excel

Если в личной книге макросов, надо заменить ThisWorkbook на ActiveWorkbook


«Черт возьми, Холмс! Но как??!!»
Ю-money 41001765434816

 

Ответить

Anis625

Дата: Четверг, 01.04.2021, 22:40 |
Сообщение № 9

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Pelena,
Все отлично работает после замены. Спасибо Вам огромное.
Маленький (не критичный нюанс) только уточню. Код не отработал две ошибки (фото во вложении) из-за чего это может быть?

К сообщению приложен файл:

9304641.png
(12.7 Kb)

 

Ответить

Pelena

Дата: Четверг, 01.04.2021, 22:51 |
Сообщение № 10

Группа: Админы

Ранг: Местный житель

Сообщений: 18797


Репутация:

4284

±

Замечаний:
±


Excel 2016 & Mac Excel

Удалите область печати с листа. Должно помочь.
Да и две ошибки можно и вручную удалить)


«Черт возьми, Холмс! Но как??!!»
Ю-money 41001765434816

 

Ответить

Anis625

Дата: Четверг, 01.04.2021, 22:57 |
Сообщение № 11

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Pelena,
Пусто там. И при копировании листа именно на них и выводится сообщение о конфликте имен.
В них вроде есть символ # который указан в коде, по идее должен снести и его тоже код

К сообщению приложен файл:

0590472.png
(20.7 Kb)

 

Ответить

Anis625

Дата: Четверг, 01.04.2021, 23:15 |
Сообщение № 12

Группа: Проверенные

Ранг: Ветеран

Сообщений: 670


Репутация:

31

±

Замечаний:
0% ±


Excel 2013

Pelena,
Марокодером записал действие удаления например заголовков печати:[vba]

Код

ActiveWorkbook.Names(«Print_Titles»).Delete

[/vba]
После запуска отдельно этого кода — не удаляет. Странно

 

Ответить

Проблемы при копировании листов внутри книги и именами

Автор John Silver, 15.04.2010, 06:37

« назад — далее »

Приветсвую всех!

возникла следующая проблема, при копировании листа выдает вполне законную ошибку о том что на новом листе будут такие же имена как и на старом, что пугает бабушек которые работают… Но основная проблема в том, что этих имен нет, т.е. в списке где я присваиваю имена пусто.

Подскажи пожалуйста где их ещё можно поискать и удалить чтобы не приходилось по несколько раз давать согласие на то что имена тебе не мешают.

Заранее благодарен.


Файл без имён выкладывайте.



Я удалили всю информацию — она не имеет значения, ошибка все равно остается. Если есть возможность расскажите где хранятся эти имена, я уже все перерыл… :(


Гад прятался здесь (см. вложение)  ;)

В 2007 — Формулы — диспетчер имён, в 2003 — не помню…
Но и там и там действует Ctrl+F3.


проблема не исчезла…  Просто попробуй скопировать лист, у меня он при этом выдает такое сообщение см. вложение…


У меня нормально работает…

Сейчас времени нет — бегу на работу.
Жди через часа полтора.

Или может кто раньше поможет.


Я проблему в принципе решил, скопировав все в новые книги, но все таки так и не понял откуда это взялось и как это убрать…


У меня всё работает…
Эксель 2007.

«Скрытые имена.

Отдельные макросы и надстройки Excel создают скрытые имена. Так называются имена, ко-
торые в рабочей книге содержатся, но в диалоговом окне Применение имени их не видно.
Например, большое количество скрытых имен создается надстройкой Поиск решения. Эти
скрытые имена можно игнорировать. Впрочем, иногда они создают проблему. При копиро-
вании листа в другую рабочую книгу скрытые имена также копируются, кроме того, они мо-
гут создать ссылку, которую трудно обнаружить,
Для удаления из рабочей книги всех скрытых имен используйте следующую процедуру VBA.

Sub DeleteHiddenNames()
Dim n As Name
Dim Count As Integer
For Each n In ActiveWorkbook.Names
If Not n.Visible Then
n.Delete
Count = Count + 1
End If
Next n
MsgBox «Скрытые имена в количестве » & Count & » удалены»
End Sub»

From «Excel 2002 Power
Programming
with VBA»
John Walkenbach



  • Профессиональные приемы работы в Microsoft Excel

  • Обмен опытом

  • Microsoft Excel

  • Проблемы при копировании листов внутри книги и именами

Понравилась статья? Поделить с друзьями:
  • Удалить сквозные строки в excel
  • Удалить символы справа в ячейке excel до символа
  • Удалить символы слева в ячейке excel до символа
  • Удалить символы с начала строки excel
  • Удалить символы до пробела в ячейке excel