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

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

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

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

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

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

Очень нужно, заранее спасибо!!!
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
14.03.2012, 00:54
Ответы с готовыми решениями:

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

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

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

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

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
14.05.2012, 18:15
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
14.05.2012, 18:15
Помогаю со студенческими работами здесь

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

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

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

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

VBA. Excel. Макрос
Доброго времени суток! Прошу помощи опытный и компетентных людей. Создала макрос при помощи...

Макрос в VBA EXCEL
Кондитерская фабрика для производства трех видов карамели А, В и С использует три вида основного...


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

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