Перейти к содержимому

Как скрыть столбцы в реальном времени на основе ввода пользователя в Excel?

Author: Xiaoyang Last Modified: 2025-08-07

Скрытие столбцов в Excel может быть обычной задачей, но пробовали ли вы когда-нибудь автоматически скрывать столбцы на основе определенных значений ввода? Например, когда я ввожу текст «AA» в ячейку, столбец A скрывается; когда я ввожу «BB», столбцы B и C скрываются; при вводе «CC» скрываются столбцы D и E; при вводе «DD» скрывается столбец F, как показано в демонстрации ниже. В этой статье будет представлен код VBA для решения этой задачи в Excel.

Использование кода VBA для скрытия или отображения столбцов в реальном времени на основе ввода пользователя

Использование кода VBA для скрытия или отображения определенных столбцов на основе ввода пользователя


Использование кода VBA для скрытия или отображения столбцов в реальном времени на основе ввода пользователя

Чтобы скрыть определенные столбцы в реальном времени на основе значений ввода, примените следующий код VBA:

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

A screenshot showing how to open the Visual Basic for Applications window in Excel by right-clicking the sheet tab

2. В открывшемся окне "Microsoft Visual Basic for Applications" скопируйте и вставьте следующий код VBA в окно "Лист (Код)".

Код VBA: Скрытие столбцов в реальном времени на основе ввода пользователя

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
'Updateby ExtendOffice
xcell = Range("K1").Value
Select Case xcell
Case "AA": Columns("A").EntireColumn.Hidden = False
Columns("A").EntireColumn.Hidden = True
Case "BB": Columns("B:C").EntireColumn.Hidden = False
Columns("B:C").EntireColumn.Hidden = True
Case "CC": Columns("D:E").EntireColumn.Hidden = False
Columns("D:E").EntireColumn.Hidden = True
Case "DD": Columns("F").EntireColumn.Hidden = False
Columns("F").EntireColumn.Hidden = True
Case Else
Columns("A:G").EntireColumn.Hidden = False
End Select
End Sub
Примечание: В приведенном выше коде "K1" — это ячейка, куда вы вводите определенный текст. Вы должны скорректировать текст и названия столбцов в соответствии с вашими потребностями. Кроме того, вы можете добавить другие новые критерии, просто добавив следующие строки кода:
  • Case "AA": Columns("A").EntireColumn.Hidden = False
  • Columns("A").EntireColumn.Hidden = True

A screenshot of the VBA code window in Excel with code pasted to hide columns based on user input

3. Затем закройте окно кода. Теперь, когда вы вводите «AA» в ячейке K1 и нажимаете клавишу "Enter", столбец A скрывается; когда вы вводите «BB» и нажимаете клавишу "Enter", столбцы B и C скрываются, и так далее. Если вы введете любое другое значение или удалите содержимое, скрытые столбцы будут немедленно отображены, см. демонстрацию ниже:


Использование кода VBA для скрытия или отображения определенных столбцов на основе ввода пользователя

В этом примере я собираюсь отфильтровать диапазон данных на основе введенного имени продукта. Когда я ввожу «Худи», отображается только информация о худи, а остальные столбцы сразу же скрываются; а когда я ввожу «Все», все столбцы отображаются, как показано в демонстрации ниже:

1. На листе, где вы хотите скрыть столбцы, щелкните правой кнопкой мыши вкладку листа, а затем выберите "Вид кода" из контекстного меню, см. скриншот:

A screenshot showing how to open the Visual Basic for Applications window in Excel by right-clicking the sheet tab

2. В открывшемся окне "Microsoft Visual Basic for Applications" скопируйте и вставьте следующий код VBA в окно "Лист (Код)".

Код VBA: Скрытие или отображение столбцов для фильтрации данных на основе ввода пользователя

Private Sub Worksheet_Change(ByVal Target As Range)
'Updateby ExtendOffice
    Dim x As Variant, y As String
     If Target.Address = "$K$1" Then
        y = Target.Value
        With Range("B1:H1")
            Application.ScreenUpdating = False
            .EntireColumn.Hidden = (y <> "All")
            If y <> "All" Then
                For Each x In .Cells
                    If x = y Then x.EntireColumn.Hidden = False
                Next
            End If
            Application.ScreenUpdating = True
        End With
    End If
End Sub
Примечание: В приведенном выше коде "K1" — это ячейка, куда вы вводите определенный текст, "B1:H1" — это заголовки строк, содержащие названия продуктов, которые вы хотите отфильтровать.

3. Затем закройте окно кода. Теперь, если вы введете название продукта в ячейку K1, будут отображаться только соответствующие столбцы, остальные будут скрыты; а если вы введете текст «Все», все столбцы появятся, как показано в демонстрации ниже:

Лучшие инструменты для повышения продуктивности в Office

🤖 Kutools AI Aide: Переворот в анализе данных на основе: Интеллектуальное выполнение   |  Сгенерировать код  |  Создать Пользовательские Формулы  |  Анализ данных и генерация диаграмм  |  Вызов Kutools Functions
Популярные функции: Найти, выделить или отметить дубликаты   |  Удалить пустые строки   |  Объединить столбцы или ячейки без потери данных   |   Округлить...
Супер ПОИСК: VLookup с несколькими критериями    VLookup с несколькими значениями  |   Многолистовой поиск   |   Распознавание нечетких соответствий ....
Расширенный раскрывающийся список: Быстро создать раскр. список   |  Зависимый раскрывающийся список   |  Множественный выбор в раскрывающемся списке ....
Менеджер столбцов: Добавить определенное количество столбцов  |  Переместить столбцы  |  Переключить статус видимости скрытых столбцов  |  Сравнить диапазоны и столбцы ...
Рекомендуемые функции: Сетка фокусировки   |  Дизайн листа   |   Улучшенная строка формулы    Управление книгой и листами   |  Библиотека автотекста (Auto Text)   |  Выбор даты   |  Объединить данные   |  Шифрование/Расшифровка ячеек    Отправить письмо по списку   |  Супер фильтр   |   Специальный фильтр (фильтр по жирному/курсиву/зачеркиванию...) ...
Топ–15 наборов инструментов: 12 текстовых инструментов (Добавить текст, Удалить определенные символы, ...)   |   50+ типов диаграмм (Диаграмма Ганта, ...)   |   40+ практических формул (Расчет возраста на основе даты рождения, ...)   |   19 инструментов вставки (Вставить QR-код, Вставить изображение из пути, ...)   |  12 инструментов преобразования (Преобразовать в слова, Конвертация валюты, ...)   |  7 инструментов объединения и разделения (Расширенное объединение строк, Разделить ячейки, ...)   |   ... и многое другое
Используйте Kutools на вашем предпочитаемом языке – поддерживаются английский, испанский, немецкий, французский, китайский и более40 других языков!

Повысьте свои навыки работы в Excel с Kutools для Excel и ощутите новую эффективность. Kutools для Excel предлагает более300 расширенных функций для повышения продуктивности и экономии времени.  Щелкните здесь, чтобы получить наиболее нужную вам функцию...


Office Tab добавляет вкладочный интерфейс в Office, делая вашу работу значительно проще

  • Включите редактирование и чтение во вкладках в Word, Excel, PowerPoint, Publisher, Access, Visio и Project.
  • Открывайте и создавайте несколько документов во вкладках одного окна, а не в новых окнах.
  • Увеличьте свою продуктивность на50% и сократите сотни кликов мышью ежедневно!