Хитрости »

Как сделать лист очень скрытым

 

Иногда возникают ситуации, когда надо скрыть лист со всем его содержимым от посторонних любопытных глаз. Очень часто это делается из контекстного меню листа (для счастливых обладателей 2007 Excel. Подробнее: здесь). Но при использовании данного метода необходимо защитить книгу, иначе отобразить скрытые листы сможет каждый (тем же правым щелчком мыши - Отобразить). А что делать, если книгу не надо защищать? Ведь часто необходимо оставить пользователям возможность работы со структурой книги, например, добавлять листы. Как тогда скрыть лист так, чтобы его нельзя было отобразить? Есть достаточно простой способ через редактор VBA, при этом обладать навыком программирования вообще не нужно. Итак, определились какой лист надо скрыть. Далее:

  1. заходим в редактор VBA(Alt+F11)
  2. жмем сочетание клавиш Ctrl+R или идем в меню View-Project Explorer (чтобы отобразить окно объектов проекта VBA)
  3. жмем F4 или через View-Properties Window (чтобы отобразить окно свойств)
  4. в левой части окна (в Project Explorer) ищем книгу, лист в которой надо скрыть и раскрываем её папку(на скрине это VBA Project (Книга1))
  5. раскрываем папку Microsoft Excel Objects и выделяем там лист с нужным именем
  6. в Окне свойств (Properties Window) находим свойство Visible и назначаем ему значение xlSheetVeryHidden

Сделать лист супер скрытым

Чтобы затем отобразить этот лист необходимо свойству Visible задать значение - xlSheetVisible. При этом для отображения листа необходимо будет обязательно зайти в редактор VBA - простым методом отобразить не получится. И книгу защищать не надо. Что нам и было необходимо.
Для большей надежности можно защитить проект VBA, чтобы не было возможности отобразить лист из VBA, не указав пароль. На функционал это не повлияет совершенно.
В том же окне VBA(Alt+F11):

  1. Tools-VBAProject Properties-вкладка Protection;
  2. для защиты устанавливается галочка "Lock project for viewing"; для разблокировки - снимается;
  3. вписывается/удаляется сам пароль в полях Password и Confirm password.

Скрыть все листы в книге, кроме листа с именем "Видимый" можно следующим макросом:

Sub Hide_All_Sheets()
    Dim wsSh As Object
    For Each wsSh In ActiveWorkbook.Sheets
        If wsSh.Name <> "Видимый" Then wsSh.Visible = xlSheetVeryHidden
        'отобразить – xlSheetVisible; сделать лист просто скрытым -  xlSheetHidden
    Next wsSh
End Sub

Также см.:
Как сделать лист скрытым?
Изменить видимость листов
Почему нет листов?


Статья помогла? Сделай твит, поделись ссылкой с друзьями!
Обсуждение: 11 комментариев
  1. toma:

    Доброго дня всем! Всё вроде получилось, но почему-то в первом окне файла НЕ отразились у меня страницы, в на втором окне файла, все листы отражаются, странно! В чём фокус-не поняла. Спасибо за внимание.

  2. Юрий:

    Добрый день. Можно ли средствами vba cкрыть программно все листы ,а отобразить на форме при помощи :optionbutton

  3. Юрий, все не получится - хотя бы один лист должен быть видимым. Как скрыть программно - в статье приведен код.
    Можно скрыть книгу: Workbooks("Имя книги.xls").Windows(1).Visible = false

  4. Lana:

    @Юрий
    Если Вам "мешает" видимый лист, поместите на него инструкцию или аннотацию к Вашей разработке. Все будут довольны.

  5. Анатолий:

    Вопрос такой: можно ли изменять данные в скрытом и запароленном листе, или для этого его нужно обязательно открыть?

  6. Виктор:

    Здорово!
    Долго искал в тексте кода, какой же командой проверяется включены макросы или нет)) Не сразу сообразил, что если макросы выключены, то код, делающий листы видимыми, просто не сработает! А листы будут всегда скрытыми, т.к. мы закрываем книгу еще при работающих макросах, и, как следствие, Workbook_BeforeClose - отработает и скроет листы.
    Красиво и остроумно.

    Прошу пояснить:
    Application.ScreenUpdating = False - без включения обновления экрана в конце макроса - это имеет какую-то причину?
    If Without End If - почему не выдает ошибку?

  7. Роман:

    Дмитрий,добрый день!
    Такой вопрос: как в последнем примере включить ограничение для каждого пользователя по вводу данных в определённых ячейках на указанных листах?!

  8. Oleg:

    Параметры VBAProject Properties\Lock project for viewing не сохраняются в файле формата .XLSX. Другими словами: пока в файле нет макросов у меня не получилось поставить пароль на Lock project for viewing.

Поделитесь своим мнением

Комментарии, не имеющие отношения к комментируемой статье, могут быть удалены без уведомления и объяснения причин. Если есть вопрос по личной проблеме - добро пожаловать на Форум


Для оформления сообщений Вы можете использовать следующие тэги:
<a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <s> <strike> <strong>

Тренинги

Заказать
Юридическая информация

Использование материалов сайта

Политика Конфиденциальности

ИП Щербаков Дмитрий Валентинович
ОГРНИП: 318502700083307
ИНН: 504013350772

Наши партнеры

Перейти
Перейти

Счетчики

Рейтинг@Mail.ru Яндекс.Метрика
© 2018 Excel для всех   Войти