Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 05.10.2025
Сообщений: 20

Заполнение данными в нескольких таблицах

06.11.2025, 17:06. Показов 1212. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. По этому коду создаю новый лист с таблицей в книге.

Visual Basic
1
2
3
4
5
Private Sub CommandButton2_Click()
ActiveSheet.Copy After:=Sheets(Sheets.Count)
ActiveSheet.Name = "copied sheet"
ActiveSheet.Name = Format(Now(), "dd-mm-yyyy")
End Sub
А по этому коду добавляю данные в таблицу.

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Dim lLastRow As Long, lRow As Long, lVal As Long
Dim tbl As ListObject
Dim rngData As Range
    Set tbl = ThisWorkbook.ActiveSheet.ListObjects("MyTbl")
    Set rngData = tbl.DataBodyRange
    lLastRow = rngData.Rows.Count
    For lVal = 1 To lLastRow
        If rngData.Rows(lVal).Text = "" Then
            lRow = lVal
            Exit For
        End If
    Next lVal
    
    If lRow = 0 Then lRow = lLastRow + 1
    With rngData
        .Cells(lRow, 1).Value = Me.TextBox1.Value
        .Cells(lRow, 2).Value = Me.ComboBox1.Value
        .Cells(lRow, 3).Value = Me.TextBox3.Value
        .Cells(lRow, 4).Value = Me.TextBox2.Value
        .Cells(lRow, 5).Value = Me.ComboBox2.Value
    End With
Проблема состоит в том,что при создании нового листа данные не добавляются с формы,возникает ошибка.
Как не привязываясь к имени таблиц заполнять их данными с формы?
Файл прилагаю.
Спасибо.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.11.2025, 17:06
Ответы с готовыми решениями:

Макрос вставки столбцов в нескольких таблицах
Уважаемые форумчане, прошу Вашей помощи. Можно ли сделать макрос вставки столбцов в определённом...

Заполнение бланка данными из формы
Здравствуйте. Очень нужен совет. Допустим имеется бланк для рецензии на дипломную работу. На нем...

Заполнение listbox данными с листа
Пытаюсь заполнить лист бокс данными из странцы экселя tempFC. Этот лист абсолютно верно и всегда...

7
0 / 0 / 0
Регистрация: 05.10.2025
Сообщений: 20
06.11.2025, 17:10  [ТС]
Вот собственно файл.
Вложения
Тип файла: xlsx Отчеты.xlsx (10.0 Кб, 7 просмотров)
0
ᴁ ©
Эксперт MS Access
 Аватар для АЕ
4136 / 2430 / 503
Регистрация: 13.12.2016
Сообщений: 8,264
Записей в блоге: 5
06.11.2025, 17:17
Цитата Сообщение от Андрей871 Посмотреть сообщение
Вот собственно файл.
в файле нет формы и кода... да и таблица пуста. Чего вставлять...
Цитата Сообщение от Андрей871 Посмотреть сообщение
данные не добавляются с формы,возникает ошибка.
Используйте теги язака программирования, а файл с кодом кладите в архив.
0
0 / 0 / 0
Регистрация: 05.10.2025
Сообщений: 20
06.11.2025, 17:32  [ТС]
Вроде исправил текст сообщения
Здравствуйте. По этому коду создаю новый лист с таблицей в книге.

'
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
 Private Sub CommandButton2_Click()
ActiveSheet.Copy After:=Sheets(Sheets.Count)
ActiveSheet.Name = "copied sheet"
ActiveSheet.Name = Format(Now(), "dd-mm-yyyy")
End Sub '
 
А по этому коду добавляю данные в таблицу.
 
' Dim lLastRow As Long, lRow As Long, lVal As Long
Dim tbl As ListObject
Dim rngData As Range
Set tbl = ThisWorkbook.ActiveSheet.ListObjects("My Tbl")
Set rngData = tbl.DataBodyRange
lLastRow = rngData.Rows.Count
For lVal = 1 To lLastRow
If rngData.Rows(lVal).Text = "" Then
lRow = lVal
Exit For
End If
Next lVal
If lRow = 0 Then lRow = lLastRow + 1
With rngData
.Cells(lRow, 1).Value = Me.TextBox1.Value
.Cells(lRow, 2).Value = Me.ComboBox1.Value
.Cells(lRow, 3).Value = Me.TextBox3.Value
.Cells(lRow, 4).Value = Me.TextBox2.Value
.Cells(lRow, 5).Value = Me.ComboBox2.Value
End With '
Проблема состоит в том,что при создании нового листа данные не добавляются с формы,возникает ошибка.
Как не привязываясь к имени таблиц заполнять их данными с формы?
Файл прилагаю.
Спасибо.
Вложения
Тип файла: 7z Отчеты.7z (7.4 Кб, 13 просмотров)
0
349 / 190 / 108
Регистрация: 01.04.2020
Сообщений: 537
06.11.2025, 23:53
Цитата Сообщение от Андрей871 Посмотреть сообщение
Как не привязываясь к имени таблиц заполнять их данными с формы?
Андрей871, возможно будет достаточно строку 12 вашего кода записать так:
Visual Basic
1
2
3
4
   ' строка 12 вашего кода по старому:
Set tbl = ThisWorkbook.ActiveSheet.ListObjects("My Tbl")
   ' строка 12 вашего кода по новому:
Set tbl = ThisWorkbook.ActiveSheet.ListObjects.Item(1)
0
Одесса - Украина
 Аватар для MikeVol
517 / 196 / 69
Регистрация: 01.04.2020
Сообщений: 610
08.11.2025, 10:56
Андрей871, Или просто замените на
Visual Basic
1
    Set tbl = ThisWorkbook.ActiveSheet.ListObjects(1)
указанную строку
Цитата Сообщение от elixi Посмотреть сообщение
возможно будет достаточно строку 12 вашего кода
0
0 / 0 / 0
Регистрация: 05.10.2025
Сообщений: 20
09.11.2025, 22:51  [ТС]
Всем привет. Можно ли обратиться к листу по цвету ярлычка?
Задача состоит в том,чтобы спрятать все листы с ялыком одного цвета,а с другим - показать. Спасибо.
0
Эксперт MS Access
 Аватар для Eugene-LS
11200 / 5802 / 1488
Регистрация: 05.10.2016
Сообщений: 16,363
09.11.2025, 23:32
Цитата Сообщение от Андрей871 Посмотреть сообщение
Можно ли обратиться к листу по цвету ярлычка?
Да, перебирая коллекцию листов и проверяя свойство: .Tab.Color
Пример:
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Dim objWorksheet As Worksheet
Dim lVal&, lColor&, sVal$
'Перебор всех листов книги
    For Each objWorksheet In ThisWorkbook.Sheets
 
        lVal = lVal + 1                   ' Номер (ID) листа
        lColor = objWorksheet.Tab.Color   ' Цвет его владки
        sVal = "Лист: " & Format$(lVal, "00") & " [" & objWorksheet.Name & "]"
        
        Debug.Print sVal & " Имеет свойство: Sheet.Tab.Color = " & lColor
        If lColor = 15773696 Then ' Если цвет синий?
            objWorksheet.Visible = Not objWorksheet.Visible
            Select Case objWorksheet.Visible
                Case True:   Debug.Print sVal & " -  Показан."
                Case False:  Debug.Print sVal & " -  Скрыт!"
            End Select
        End If
    Next objWorksheet
 
    Set objWorksheet = Nothing
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.11.2025, 23:32
Помогаю со студенческими работами здесь

Заполнение данными FlexGrid значениями из БД
Дайте пожалуйста у кого есть код для заполнения FlexGrid данными с базы. Через набор записей...

Заполнение именованного диапазона данными из другого диапазона по условию: код не работает
Заполняю таблицу с данными о пищевой ценности продуктов. Простейший скрипт, ищущий совпадение в...

Заполнение данными таблицу по по поиску
Привет всем, Нужна помощь. Пример вложил. Есть некий список, где ежедневно меняются статусы...

Заполнение книги Excel данными из документа Word
Добрый день. Пролистал около десятка тем на этом форуме и еще на нескольких, так и не смог найти...

Заполнение шаблона документа excel данными из БД (SQL SERVER)
Сил больше нету искать решение. Ребята, помогите. Нужно из vb6 открыть шаблон документа excel и...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru