📋 Элемент управления ListView
ListView (вид списка, представление списка) — элемент управления, который позволяет отображать данные в виде значков, списка или таблицы внутри формы VBA Excel. Чаще всего ListView используется для отображения данных в виде таблицы - режим Отчет (lvwReport).
🎈 Добавление ListView на UserForm
1️⃣ Откройте редактор VBA (Alt + F11).
2️⃣ В редакторе VBA выберите Tools → References.
3️⃣ Найдите и активируйте библиотеку Microsoft Windows Common Controls, если она ещё не активирована.
4️⃣ Создайте новую форму (Insert → UserForm).
5️⃣ Если панели элементов управления не видно, откройте ее (View → Toolbox).
6️⃣ Щелкните правой кнопкой мыши на панели элементов управления и выберите «Additional Controls…» (Дополнительные элементы управления…).
7️⃣ Найдите «Microsoft ListView Control» и добавьте его на панель.
8️⃣ Перетащите элемент ListView с панели элементов на вашу UserForm.
📌 Пример заполнения ListView
Пример отображения списка сотрудников с их ФИО, должностью и отделом:
Вставьте код примера в модуль UserForm. Результат работы кода представлен на изображении ниже.
#VBA #Excel #ListView #Отчет #Report
ListView (вид списка, представление списка) — элемент управления, который позволяет отображать данные в виде значков, списка или таблицы внутри формы VBA Excel. Чаще всего ListView используется для отображения данных в виде таблицы - режим Отчет (lvwReport).
🎈 Добавление ListView на UserForm
1️⃣ Откройте редактор VBA (Alt + F11).
2️⃣ В редакторе VBA выберите Tools → References.
3️⃣ Найдите и активируйте библиотеку Microsoft Windows Common Controls, если она ещё не активирована.
4️⃣ Создайте новую форму (Insert → UserForm).
5️⃣ Если панели элементов управления не видно, откройте ее (View → Toolbox).
6️⃣ Щелкните правой кнопкой мыши на панели элементов управления и выберите «Additional Controls…» (Дополнительные элементы управления…).
7️⃣ Найдите «Microsoft ListView Control» и добавьте его на панель.
8️⃣ Перетащите элемент ListView с панели элементов на вашу UserForm.
📌 Пример заполнения ListView
Пример отображения списка сотрудников с их ФИО, должностью и отделом:
Private Sub UserForm_Initialize()
' Настройка формы
With Me
.Caption = "Список сотрудников"
.Width = 300
.Height = 160
End With
With Me.ListView1
' Настройка режима отображения
.View = lvwReport
.Gridlines = True
.FullRowSelect = True
.Left = Me.Left
.Top = Me.Top
.Width = Me.Width ' По ширине разворачиваем на всю форму
.Height = Me.Height - 70 ' Внизу оставляем место для кнопок
' Добавляем колонки с заголовками и задаем ширину
.ColumnHeaders.Add , , "ID", 30 ' Заголовок 1, но столбец 0
.ColumnHeaders.Add , , "ФИО", 80 ' Заголовок 2, но столбец 1
.ColumnHeaders.Add , , "Должность", 80 ' Заголовок 3, но столбец 2
.ColumnHeaders.Add , , "Отдел", 105 ' Заголовок 4, но столбец 3
' Добавляем строки
Dim itm As ListItem
Set itm = .ListItems.Add(, , "1") ' Элемент 1 строки (0 столбец)
itm.SubItems(1) = "Иванов И.И." ' Подэлемент 1 строки (1 столбец)
itm.SubItems(2) = "Менеджер" ' Подэлемент 1 строки (2 столбец)
itm.SubItems(3) = "Отдел продаж" ' Подэлемент 1 строки (3 столбец)
Set itm = .ListItems.Add(, , "2")
itm.SubItems(1) = "Петров П.П."
itm.SubItems(2) = "Аналитик"
itm.SubItems(3) = "Финансовый отдел"
Set itm = .ListItems.Add(, , "3")
itm.SubItems(1) = "Сидоров С.С."
itm.SubItems(2) = "Программист"
itm.SubItems(3) = "ИТ-отдел"
End With
End Sub
Вставьте код примера в модуль UserForm. Результат работы кода представлен на изображении ниже.
#VBA #Excel #ListView #Отчет #Report
👍6
🔢 Сортировка данных в ListView
Чтобы сортировать данные в табличных отчетах ListView, добавьте следующий код VBA Excel в модуль формы:
Теперь при клике по заголовку любого столбца произойдет сортировка строк по данным этого столбца. При первом клике будет порядок сортировки — по убыванию, при втором — по возрастанию, при третьем — снова по убыванию и так далее.
💡 Небольшое пояснение для поста выше:
В таблицах ListView нумерация столбцов начинается с 0 (ColumnHeader.SubItemIndex), а нумерация заголовков столбцов - с 1 (ColumnHeader.Index).
#VBA #Excel #ListView #Сортировка #Sort #ColumnHeader
Чтобы сортировать данные в табличных отчетах ListView, добавьте следующий код VBA Excel в модуль формы:
Private Sub ListView1_ColumnClick(ByVal ColumnHeader As MSComctlLib.ColumnHeader)
With Me.ListView1
.Sorted = True
.SortKey = ColumnHeader.SubItemIndex ' Сортировка по выбранному столбцу
.SortOrder = IIf(.SortOrder = 1, 0, 1) ' Переключение порядка сортировки
End With
End Sub
Теперь при клике по заголовку любого столбца произойдет сортировка строк по данным этого столбца. При первом клике будет порядок сортировки — по убыванию, при втором — по возрастанию, при третьем — снова по убыванию и так далее.
💡 Небольшое пояснение для поста выше:
В таблицах ListView нумерация столбцов начинается с 0 (ColumnHeader.SubItemIndex), а нумерация заголовков столбцов - с 1 (ColumnHeader.Index).
#VBA #Excel #ListView #Сортировка #Sort #ColumnHeader
❤4👍4
Доступ к данным в таблице ListView
Вывод данных из выделенной строки в таблице ListView с помощью кода VBA Excel на примере таблицы со скриншота выше.
Добавьте на форму с ListView элемент управления CommandButton1 (кнопка) и в модуль формы вставьте следующий код:
Откройте форму с ListView, выберите строку и нажмите кнопку CommandButton1. Информационное окно MsgBox отобразит данные из выделенной строки.
#VBA #Excel #ListView #Данные #Вывод
Вывод данных из выделенной строки в таблице ListView с помощью кода VBA Excel на примере таблицы со скриншота выше.
Добавьте на форму с ListView элемент управления CommandButton1 (кнопка) и в модуль формы вставьте следующий код:
Private Sub CommandButton1_Click()
Dim sItem As ListItem
Set sItem = ListView1.selectedItem
If Not sItem Is Nothing Then
MsgBox "Выбрана строка:" & vbNewLine & _
"ID = " & sItem.Text & vbNewLine & _
"ФИО = " & sItem.ListSubItems(1).Text & vbNewLine & _
"Должность = " & sItem.ListSubItems(2).Text & vbNewLine & _
"Отдел = " & sItem.ListSubItems(3).Text
Else
MsgBox "Строка не выбрана!"
End If
End Sub
Откройте форму с ListView, выберите строку и нажмите кнопку CommandButton1. Информационное окно MsgBox отобразит данные из выделенной строки.
#VBA #Excel #ListView #Данные #Вывод
❤5
📋 ListView в режиме lvwSmallIcon
ListView в режиме lvwSmallIcon - это более удачный вариант, чем ListView в режиме lvwIcon. По крайней мере, на моём программном обеспечении.
Пример использования ListView в режиме lvwSmallIcon
1️⃣ Подключите библиотеку Microsoft Windows Common Controls 6.0 (SP6), если она не подключена.
2️⃣ Добавьте на панель Toolbox элементы управления «Microsoft ListView Control» и «Microsoft ImageList Control».
3️⃣ Создайте новую форму и перетащите на неё элементы ListView, ImageList и CommandButton с панели элементов управления (Toolbox).
4️⃣ Создайте несколько иконок (в примере их 5 штук) и поместите их в папку с именем «Test» на диске «C».
5️⃣ В модуль формы вставьте следующий код:
Запустите форму, нажав на треугольник (Run Sub/UserForm) или на клавишу F5. Результат работы кода на скриншоте ниже.
#VBA #Excel #ListView #Icon #Значок #Иконка
ListView в режиме lvwSmallIcon - это более удачный вариант, чем ListView в режиме lvwIcon. По крайней мере, на моём программном обеспечении.
Пример использования ListView в режиме lvwSmallIcon
1️⃣ Подключите библиотеку Microsoft Windows Common Controls 6.0 (SP6), если она не подключена.
2️⃣ Добавьте на панель Toolbox элементы управления «Microsoft ListView Control» и «Microsoft ImageList Control».
3️⃣ Создайте новую форму и перетащите на неё элементы ListView, ImageList и CommandButton с панели элементов управления (Toolbox).
4️⃣ Создайте несколько иконок (в примере их 5 штук) и поместите их в папку с именем «Test» на диске «C».
5️⃣ В модуль формы вставьте следующий код:
Private Sub UserForm_Initialize()
' Настройка формы
With Me
.Caption = "Сообщество смурфов"
.Width = 350
.Height = 250
End With
' Настройка кнопки
With CommandButton1
.Caption = "Выбрать"
.Width = 60
.Height = 24
.Top = Me.Height - 70
.Left = Me.Width / 3 + 20
.Font.Size = 10
End With
' Настройка ListView
With ListView1
.View = lvwSmallIcon
.LabelEdit = lvwManual
.Sorted = True
.MultiSelect = False
.HideSelection = False
.FullRowSelect = False
.Left = Me.Left
.Top = Me.Top
.Width = Me.Width ' По ширине разворачиваем на всю форму
.Height = Me.Height - 80 ' Внизу оставляем место для кнопок
End With
With ImageList1.ListImages
.Add , "PapaSmurf", LoadPicture("C:\Test\PapaSmurf.ico")
.Add , "Smurfette", LoadPicture("C:\Test\Smurfette.ico")
.Add , "BrainySmurf", LoadPicture("C:\Test\BrainySmurf.ico")
.Add , "GutsySmurf", LoadPicture("C:\Test\GutsySmurf.ico")
.Add , "ClumsySmurf", LoadPicture("C:\Test\ClumsySmurf.ico")
End With
' Привязка ImageList к ListView
Set ListView1.SmallIcons = ImageList1
' Добавление элементов с иконками
With ListView1.ListItems
.Add , , "Папа Смурф", , "PapaSmurf"
.Add , , "Смурфетта", , "Smurfette"
.Add , , "Смурф Знайка", , "BrainySmurf"
.Add , , "Смурф Храбрец", , "GutsySmurf"
.Add , , "Смурф Растяпа", , "ClumsySmurf"
End With
End Sub
Запустите форму, нажав на треугольник (Run Sub/UserForm) или на клавишу F5. Результат работы кода на скриншоте ниже.
#VBA #Excel #ListView #Icon #Значок #Иконка
👍3❤1
📋 ListView в режиме lvwSmallIcon (продолжение)
Для определения, какой элемент ListView1 выбран, добавьте в модуль формы процедуру для кнопки:
Теперь при нажатии на кнопку «Выбрать», информационное окно будет выводить текст выбранного элемента.
#VBA #Excel #ListView #Icon #Значок #Иконка
Для определения, какой элемент ListView1 выбран, добавьте в модуль формы процедуру для кнопки:
Private Sub CommandButton1_Click()
MsgBox ListView1.selectedItem.Text
End Sub
Теперь при нажатии на кнопку «Выбрать», информационное окно будет выводить текст выбранного элемента.
#VBA #Excel #ListView #Icon #Значок #Иконка
👍3🔥2❤1