Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/18: Рейтинг темы: голосов - 18, средняя оценка - 4.78
ekunevich
1

Копирование данных из нескольких таблиц в одну

30.08.2012, 16:54. Показов 3270. Ответов 4
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Доброго времени суток. Передо мной стоит задача: есть книга, в которой содержится N-ное количество листов, на каждом листе находится таблица. В каждой из этих таблиц содержатся свои данные, но несколько столбцов совпадают по смыслу: A - Наименование, B - Единица измерения, V - Количество с учетом остатков. Имеется итоговая таблица, в которую должны заливаться эти столбцы из всех других таблиц. Есть условия: т. к. уже имиеющиеся таблицы заполняют разные люди, то в итоговой таблице данные из разных таблиц должны быть как-то разделены; также если любой из пользователей добавляет новую строку в свою таблицу, то эта строка должна автоматически появляться в итоговой таблице аналогично строке в исходной. Если кто-то сможет помочь, буду очень признательна. Если что-то не совсем понятно изложила, спросите, попытаюсь дать более понятный ответ. Спасибо.
Вложения
Тип файла: rar Таблицы.rar (75.3 Кб, 44 просмотров)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
30.08.2012, 16:54
Ответы с готовыми решениями:

Подгрузка данных из нескольких таблиц в одну
Доброго времени суток, профессионалы экстра класса! Требуется помощь в написании макроса по...

Вывод данных из нескольких таблиц в одну
Здравствуйте. Требуется построить запрос, что бы из таблиц Bloki_Pitaniya, Jestkie_Diski, Korpusa,...

Объединение данных из нескольких таблиц в одну
Здравствуйте уважаемые участники форума. Прошу помочь советом, как решить такую задачку. ...

Запрос на выборку данных из нескольких таблиц в одну
Здравствуйте! В общем, проблема такая.. Нужно мне составить отчет, который содержит данные из...

4
1301 / 403 / 22
Регистрация: 21.10.2011
Сообщений: 1,285
30.08.2012, 17:27 2
ekunevich, вам это надо для работы или для учёбы?
0
11517 / 3803 / 681
Регистрация: 13.02.2009
Сообщений: 11,221
31.08.2012, 06:56 3
Можно макросом перебирать листы и дописывать
Вот только соответствие
"Цена РБ" "Цена РФ" "Цена Э" Ед.изм. Количество "Сумма РБ" "Сумма РФ" "Сумма Э"
нужно знать.
Или только A - Наименование, B - Единица измерения, V - Количество выбрать?

Добавлено через 52 минуты
Примерно так. Макрос можно запускать, например, по кнопке на итоговом листе либо периодически таймером
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
Sub Выборка()
Dim Lr, R, Ld
Dim SH As Worksheet
Dim Si As Worksheet
Set Si = Worksheets("итоговая таблица")
Si.Rows("4:50000").ClearContents
Si.Rows("4:50000").Font.Bold = False
    For Each SH In ActiveWorkbook.Worksheets
   ' Debug.Print SH.Name
        If SH.Name <> "итоговая таблица" Then
            With SH
            Lr = .Cells(Rows.Count, 1).End(xlUp).Row
            Ld = Si.Cells(Rows.Count, 1).End(xlUp).Row + 2
                Si.Cells(Ld, 1) = SH.Name
                Si.Cells(Ld, 1).Font.Bold = True
                For R = 5 To Lr
                Ld = Ld + 1
                Si.Cells(Ld, 1).Value = .Cells(R, 1).Value
                Si.Cells(Ld, 6).Value = .Cells(R, 2).Value
                Si.Cells(Ld, 7).Value = .Cells(R, 22).Value
                Next R
            End With
        End If
    Next
    MsgBox "Ok", 64, ""
End Sub
1
ekunevich
31.08.2012, 10:41 4
Busine2012, для работы

Добавлено через 2 минуты
Цитата Сообщение от Alex77755 Посмотреть сообщение
Можно макросом перебирать листы и дописывать
Вот только соответствие
"Цена РБ" "Цена РФ" "Цена Э" Ед.изм. Количество "Сумма РБ" "Сумма РФ" "Сумма Э"
нужно знать.
Или только A - Наименование, B - Единица измерения, V - Количество выбрать?
Спасибо огромное, все работает, файл с ценами мне еще не давали, пока сказали сделать хотя бы это, спасибо еще раз, очень выручили

Добавлено через 1 час 12 минут
Скажите, пожалуйста, а можно ли сделать так, чтобы приведенный выше макрос выполнялся при каждом изменении на любом из листов, кроме итогового?
11517 / 3803 / 681
Регистрация: 13.02.2009
Сообщений: 11,221
31.08.2012, 11:01 5
Можно, но зачем. Тормозить будет.
Проще поставить на открытие именно этого листа

Добавлено через 5 минут
Visual Basic
1
Private Sub Workbook_SheetActivate(ByVal Sh As Object)
В это событие поставить проверку имени листа и если "итоговая таблица", то запустить макрос
0
31.08.2012, 11:01
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
31.08.2012, 11:01
Помогаю со студенческими работами здесь

Поиск в документе, копирование данных нескольких однотипных таблиц в новый документ
Знатоки, помогите пожалуйста, целый день ищу нечто подобное, своих знаний в VBA не хватает....

Копирование из нескольких книг в одну
Здравствуйте есть такой вопрос мне нужно копировать несколько книг в одну, но из нескольких книг...

Объединение нескольких таблиц в одну
Добрый день! Excel'ем приходится пользоваться нечасто, поэтому прошу не пинать :) Суть...

Объединение нескольких таблиц в одну
вот есть 5 таблиц test_1,test_2.....5 , у них всего два поля id(autoincrement) и word(varchar(50))...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru