Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/54: Рейтинг темы: голосов - 54, средняя оценка - 4.56
 Аватар для virtual[ity]
165 / 143 / 66
Регистрация: 05.06.2010
Сообщений: 641
1

Excel VBA макрос, добавляющий записи к таблице через Inputbox

14.03.2012, 00:54. Показов 10336. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем привет! Помогите пожалуйста написать такой макрос в Excel VBA :

Создать макрос, создающий и заполняющий 5 записями таблицу на листе, с полями: Товар, Количество, Цена, Стоимость партии. Ввод данных через Inputbox (последнее поле вычисляется).

Создать макрос, который во всех открытых книгах в ячейку «А5» второго листа записывает имя этой книги.

Очень нужно, заранее спасибо!!!
0
14.03.2012, 00:54
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.03.2012, 00:54
Ответы с готовыми решениями:

Сохранение Excel-файла через макрос VBA в Access
Добрый день. полная информация есть здесь:https://www.cyberforum.ru/ms-access/thread1786317.html подскажите если сможете, при...

Распознавание текста с картинки из PDF через макрос (средствами vba excel)
Добрый день! Ув. Форумчане! Нужно сделать так, что-бы через vba excel макрос, вытаскивать текст из картинки которая в PDF, средствами...

Найти нужную запись в таблице Access'а через VBA Excel
Народ, никак не получается!!! И как если нашел сделать ее текущей??? Поделитесь куском кода! Очень надо!!! Вот что у меня есть: Dim...

1
1301 / 403 / 22
Регистрация: 21.10.2011
Сообщений: 1,285
14.05.2012, 18:15 2
  1. Закройте все книги Excel.
  2. Откройте несколько чистых книг Excel.

По первому заданию:
предполагается, что на активном листе данные начинаются со столбца "A", а в первую строку занесены названия столбцов.
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
Sub Procedure1()
 
    'Создаём на пластинке оперативной памяти поименованную область - переменную.
    'Long означает, что в переменной могут быть только целые числа (есть ещё дробные).
    Dim lLastRow As Long
    'String означает, что в переменной может быть только текст.
    Dim sResponse As String
    Dim i As Long
    
    'Определяем последнюю заполненную строку на листе,
    'чтобы знать, куда заносить очередные данные.
    
    'Rows.Count - это количество строк на листе.
    'End(xlUp) - это то же самое, что нажать в Excel сочетание клавиш
    'Ctrl + стрелка вверх, что означает переход к первой заполненной ячейке.
    'С помощью Row берём номер строки, первой заполненной ячейки.
    
    'Т.е. следующий код вручную через Excel делается так:
    'делаете активной ячейку в последней строке листа в столбце "A"
    '(последняя строка на листе 65000 или 1000000) и нажимаете
    'сочетание клавиш Ctrl + стрелка вверх. Затем читает номер строки,
    'куда перешла рамка выделения.
    lLastRow = Cells(Rows.Count, "A").End(xlUp).Row + 1
    
    'Вводим на активный лист Excel данные.
    
    'For ... To ... Step ... Next - называется циклом и используется,
    'чтобы делать одно и то же действие заданное количество раз.
    'В нашем случае - это 5 раз.
    
    For i = 1 To 5 Step 1
    
        'С помощью InputBox помещаем в переменную sResponse данные.
        'Если пользователь нажмёт в InputBox "Cancel" или крестик, то в переменную
        'поместится текст: "" (пустая строка), что будет сигналом,
        'что нужно завершить цикл.
        sResponse = InputBox("Введите Товар")
        
        'If ... Then ... End If - используется для выбора действия.
        If sResponse = "" Then
            'Выходим из цикла.
            Exit For
        End If
        
        Cells(lLastRow, "A").Value = sResponse
        
        sResponse = InputBox("Введите Количество")
        If sResponse = "" Then
            Exit For
        End If
        Cells(lLastRow, "B").Value = sResponse
        
        sResponse = InputBox("Введите Цену")
        If sResponse = "" Then
            Exit For
        End If
        Cells(lLastRow, "C").Value = sResponse
        
        'Четвёртный столбец подсчитаем с помощью кода.
        Cells(lLastRow, "D").Value = Cells(lLastRow, "B").Value * Cells(lLastRow, "C").Value
        
        'Чтобы записывать данные в следующую пустую строку.
        lLastRow = lLastRow + 1
    Next
 
    'Сообщение, что работа кода завершена.
    MsgBox "Работа кода завершена!", vbInformation
    
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
22
23
24
25
Sub Procedure2()
 
    'Переменная oBook - это имя, которое будет даваться книгам
    'во время выполнения кода. Через это имя будем манипулировать листами.
    Dim oBook As Excel.Workbook
 
    'For ... Each ... In ... Next - это цикл для просмотра всех одинаковых элементов.
    'В нашем случае одинаковыми элементами будут книги.
    For Each oBook In Workbooks
 
        'Чтобы не заносить данные в личную книгу макросов.
        
        'LCase - используется, чтобы переводить текст в маленькие буквы,
        'чтобы можно было сравнивать два текста. Т.к. по умолчанию
        'учитывается регистр текста.
        
        'С помощью InStr - определяем, есть ли в начале имени файла
        'слово "personal".
        
        If InStr(LCase(oBook.Name), "personal") <> 1 Then
            oBook.Worksheets(2).Range("A5").Value = oBook.Name
        End If
    Next oBook
 
End Sub
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
14.05.2012, 18:15
Помогаю со студенческими работами здесь

Поиске через inputbox по таблице
В поиске нужно вводить данные, например номер телефона, и вместо, скажем, неизвестных цифер нужно ставить *. Программа должна искать данные...

Макрос, добавляющий листы
Здравствуйте, помогите пожалуйста. Требуется написать макрос, добавляющий к имеющимся трем листам нового файла Excel еще 5 листов и...

Макрос, добавляющий 5 листов
добрый день . подскажите пожалуйста, как решить данный вопрос. было задание:Написать макрос , добавляющий к имеющимся 3 листам еще ...

Макрос Excel Vba
Написать макрос в Excel, ввод и вывод данных из таблицы. Задание во вложении.

макрос в Excel VBA
Создать макрос, который копирует выделенную область страницы в другую область другого листа (область и лист задает пользователь во время...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Использование кэша Laravel - полный гайд
bytestream 18.02.2025
Кэширование - один из наиболее эффективных способов повышения производительности веб-приложений. В современном мире, где скорость загрузки страниц напрямую влияет на удержание пользователей и. . .
Создаем REST API в Laravel с аутентификацией через Passport
bytestream 18.02.2025
Разработка современных веб-приложений все чаще требует создания надежного и хорошо структурированного API. REST API стал стандартом де-факто для построения взаимодействия между клиентской и серверной. . .
Пайплайны в Laravel - полный гайд
bytestream 18.02.2025
Разработка современных веб-приложений часто требует обработки сложных процессов, состоящих из множества последовательных шагов. Например, при создании системы комментариев может потребоваться. . .
Как правильно использовать @required в Symfony
bytestream 18.02.2025
При разработке приложений на Symfony мы часто сталкиваемся с необходимостью внедрения зависимостей. Фреймворк предоставляет несколько способов управления этим процессом, и одним из таких инструментов. . .
Система безопасности в Laravel: возможности и примеры
Wired 18.02.2025
Каждый день появляются новые виды атак и уязвимостей, которые могут поставить под угрозу конфиденциальные данные пользователей и функционирование всей системы. В этом контексте выбор надежного. . .
Давайте сравним Django и Laravel
Wired 18.02.2025
Django и Laravel - два мощных инструмента, которые часто сравнивают между собой. Оба фреймворка предлагают разработчикам богатый набор возможностей для создания масштабируемых веб-приложений, но. . .
Laravel или React - что лучше?
Wired 18.02.2025
В разработке веб выбор правильного инструмента часто определяет успех всего проекта. Особенно интересным представляется сравнение Laravel и React - двух популярных технологий, которые часто. . .
Laravel 11: новые возможности, гайд по обновлению
Wired 18.02.2025
Laravel 11 - это новая масштабная версия одного из самых популярных PHP-фреймворков, выпущенная в марте 2024 года. Эта версия продолжает традицию внедрения передовых технологий и методологий. . .
Миграции в Laravel
Wired 18.02.2025
Разработка веб-приложений на Laravel неразрывно связана с управлением структурой базы данных. При работе над проектом часто возникает необходимость вносить изменения в схему базы данных - добавлять. . .
Аутентификация в Laravel
Wired 18.02.2025
В современном мире веб-разработки безопасность пользовательских данных становится критически важным аспектом любого приложения. Laravel, как один из самых популярных PHP-фреймворков, предоставляет. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru