Глава 3.

В этой главе мы рассмотрим несколько практических задач, связанных с автоматизацией офисной деятельности, которые встретились на практике в организации, занимающейся поставками крупной строительной техники. Мы постарались рассмотреть модель, которая лишена ряда ненужных подробностей, которые скорее отвлекут внимание читателя. Каждая из рассматриваемых далее разработок представляет отдельную книгу Microsoft Excel, которая позволяет эффективно сотруднику офиса вести работу.

В плане новых сведений по VBA эта поможет вам на практике познакомиться с разработкой форм ввода, которые являются неотьемлимым атрибутом любой разработки. Наверняка, задачи, которые мы далее рассмотрим имеют аналоги и в деятельности вашей организации.

Организация, применительно к которой, относится рассматриваемая далее разработка занимается поставками покупателям дорогостоящей строительной техники. Кроме того, еще один из участков деятельности связан с ремонтом.

Автоматизация заполнения списка заказа в фирме занимающейся ремонтом

Разрабатываемая далее книга Microsoft Excel будет включать несколько листов данных и листов управления. Будем считать, что мы располагаем рядом клиентов (заказчиков), которые обращаются к нам по поводу ремонта их техники. Сам ремонт, как правило, связан с заменой большого количества деталей. Учитывая это очевидно, что основные трудности работы персонала связаны с обеспечением хранения и извлечения необходимой информации по каждому договору с клиентом, а также с формированием отчетов по клиентам и договорам.

НЕ нашли? Не то? Что вы ищете?

В рабочей книге Microsoft Excel мы разработаем единую информационную базу, которая позволит существенно облегчить труд сотрудников офиса. Облегчение работы будет достигнуто за счет программирования необходимых элементов управления.

Итак, создадим новую рабочую книгу. Ее первый лист, который нам потребуется создать показан на рис.3.1. В нем размещается справочная информация по нашим заказчикам (клиентам). Каждая строка на листе Клиенты представляет запись об одной из наших организаций-партнеров. Обратим внимание на то, что в дальнейшем при программном обращение к данному листу будет производиться по имени, поэтому следует присвоить ему имя Клиенты.

Столбец Код предназначен для присвоения каждой фирме уникального кода (для того, чтобы однозначно идентифицировать каждую фирму). Это исключит возможные ошибки в случае, если фирмы будут иметь одинаковое название. Информация представленная в столбцах на рис.3.1 достаточно стандартна – название, адрес, телефон, факс и ряд финансовых реквизитов.

Рис.3.1.

В верхней части листа располагается кнопка для ввода очередной записи – записи о новой фирме. Конечно, пользователь, при появлении у нашей фирмы очередного партнера может внести информацию о нем в очередную свободную строку. Однако для удобства с одной стороны и контроля возможных ошибок с другой мы разработаем более удобную технологию. Программная процедура при этом будет самостоятельно отслеживать появление повторяющихся кодов фирм, а также непосредственно дублирующих записей об одной и той же фирме.

Во-первых, нам потребуется создать форму ввода, которая приведена на рис.3.2. От пользователя требуется внести данные в необходимые поля и щелкнуть по кнопке для фиксации данных на листе Клиенты. Такие действия приведут к тому, что в очередную свободную строку листа будет внесена информация по новой фирме. При этом процедура обработки щелчка по кнопке Внести предварительно проверит – встречался ли уже такой код у фирм? Если да, то ввод будет отменен. Также ввод будет отменен, если пользователь оставит поле пустым. Кроме того, процедура посмотрит – не является ли данная запись дублирующей.

Рис.3.2.

Таким образом, наша ближайшая цель – создать форму ввода (рис.3.2) и расположить на ней необходимые элементы управления. С формами в этом издании мы еще не сталкивались, поэтому рассмотрим процесс ее создания более подробно.

Для создания пользовательской формы необходимо перейти в окно Microsoft Visual Basic (рис.3.3). Здесь требуется воспользоваться разделом UserForm в меню Insert. В результате на экране перед вами появится новая форма, которая фактически представляет собой контейнер для расположения на ней необходимых элементов управления.

У формы, как и любого элемента управления, есть свойства. Для того, чтобы открыть окно свойств следует воспользоваться разделом Properties Window из меню View. Изменим значение Name на Client, а также значение свойства Caption – Форма для ввода нового клиента. В результате в заголовке формы будет отражено новый заголовок.

Далее расположим на форме необходимые элементы управления. Для этого сначала необходимо отобразить на экране панель инструментов (располагается в правом нижнем углу на рис.3.3). Вывести эту панель можно с помощью раздела Toolbox в меню View.

В соответствие с рис.3.2 на форме нам необходимо разместить 7 элементов типа Надпись и 7 элементов типа Текстовое окно. При этом значения свойства Name для надписей принципиального значения не имеет, т. к. программно мы обращаться к ним не будем. Для этих элементов выберите рассматриваемые значения произвольно (главное, что не было повторяющихся имен). Аналогичное свойство для текстовых окон нам потребуется, поэтому в таблице 3.1 приведены имена для текстовых окон которые следует установить.

Рис.3.3.

Таблица 3.1. Значения свойства Name для текстовых окон

Подпись

Name

Код

Cod

Название фирмы

Firma

Адрес

Adress

Телефон

Tel

Факс

Fax

ИНН

Inn

КПП

Kpp

От пользователя требуется внести информацию в текстовые окна, расположенные на форме, после чего щелкнуть по кнопке Внести. Это приводит к выполнению процедуры, которая должна предварительно проверить корректность вводимых данных. Если на листе запись с указанным кодом фирмы уже существует, то процедура обратит на это внимание. Также процедура обратит внимание, если на листе уже присутствует фирма с аналогичным названием и с тем же указанным адресом. Текст этой процедуры приведен на листинге 3.1.

Листинг 3.1. Обработка щелчка по кнопке Внести.

Private Sub CommandButton1_Click()

If Cod. Text = “” Then

MsgBox ("Поле код необходимо заполнить")

Exit Sub

End If

Nom = 0

While Worksheets(“Клиенты”).Cells(Nom + 2, 2).Value <> ""

Nom = Nom + 1

Wend

For i = 1 To Nom

If CStr(Worksheets(“Клиенты”).Cells(i + 1, 2).Value) = _

CStr(Firma. Text) And _

CStr(Worksheets(“Клиенты”).Cells(i + 1, 3).Value) = _

CStr(Adress. Text) Then

MsgBox ("Такая фирма уже присутствует")

Exit Sub

End If

If CStr(Worksheets(“Клиенты”).Cells(i + 1, 1).Value) = _

CStr(Cod. Text) Then

MsgBox ("Такой код фирмы уже встречался")

Exit Sub

End If

Next

Worksheets(“Клиенты”)..Cells(i + 1, 1).Value = Cod. Text

Worksheets(“Клиенты”)..Cells(i + 1, 2).Value = Firma. Text

Worksheets(“Клиенты”).Cells(i + 1, 3).Value = Adress. Text

Worksheets(“Клиенты”).Cells(i + 1, 4).Value = Tel. Text

Worksheets(“Клиенты”).Cells(i + 1, 5).Value = Fax. Text

Worksheets(“Клиенты”).Cells(i + 1, 6).Value = Inn. Text

Worksheets(“Клиенты”).Cells(i + 1, 7).Value = Kpp. Text

MsgBox ("Информация внесена")

Client. Hide

End Sub

Важный момент связан с предпоследней строкой листинга 3.1. Здесь для формы Client применяется метод Hide, который приводит к закрытию формы. Разумеется, ее необходимо сначала отобразить и об этом мы еще не говорили. На листинге 3.2 приведена процедура, которая выполняется по щелчку по кнопке Внести нового клиента на рис.3.1. Для отображения на экране формы Client используется метод Show.

Листинг 3.2. Обработка щелчка по кнопке Внести нового клиента.

Private Sub CommandButton1_Click()

Client. Show

End Sub

На рис. 3.4 приведен результат заполнения формы данными о фирме. Теперь щелчком по кнопке Внести эти данные переносятся на текущий рабочий лист.

Рис.3.4.

Перейдем к разработке еще двух листов. Один из них под названием Номенклатура показан на рис.3.5. В каждой строке листа располагается название конкретной запчасти. Поле Номер запчасти позволяет однозначно ее идентифицировать.

Рис.3.5.

Лист Номенклатура является справочным, и не содержит элементов управления. Технически пользователь просто вручную заполняет этот прайс. Еще один лист, который также не содержит элементов управления, показан на рис.3.6.

Рис.3.6.

Данный лист содержит информацию о заказах – названиях и их составе. Во-первых, в столбце А указывается уникальный код для каждого заказа. Далее располагаются поля для отражения даты заказа и кода фирмы (по коду фирмы легко определить реквизиты фирмы). Начиная с 5-го столбца размещается информация о запчастях, которые входят в заказ. Структура этой информации выглядит следующим образом: в 5-й колонке код запчасти, далее в 6-й количество таких запчастей в заказе, затем в 7-й колонке код другой запчасти и следом количество. Таким образом, в каждой строке перечислено все содержимое заказа.

Понятно, что вручную заполнять подобную информацию не удобно. Для этого мы создадим специальный лист с необходимыми элементами управления. В результате будет обеспечено удобство для пользователя, а также контроль уникальности номера заказа. Лист, который будет выполнять необходимый функционал показан на рис.3.7.

Рис.3.7.

Рассмотрим теперь техническую работу пользователя с листом Бланк для нового заказа. Ячейка С1 отводится для названия заказа. Ниже подписи Список запчастей располагается элемент управления Поле со списком. Щелчком по определенной запчасти она включается в заказ, который начинается с 11-й строки на данном листе. Здесь колонки Номер запчасти, Наименование и Цена заполняется исходя из имеющейся информации на листе Номенклатура. Пользователю следует лишь внести количество единиц указанной запчасти в списке заказа. Для этого предназначено текстовое окно с подписью Количество. Далее осталось щелкнуть по кнопке Включить и в очередную свободную строку на данном листе запишется строка заказа. После того, как список запчастей заполнен и номер заказа указан осталось щелкнуть по кнопке Включить в список заказов. Это приведет к переносу информации о заказе на лист Названия заказов.

Теперь перейдем к рассмотрению процедур, которые обеспечивают выполнение описанных действий. Когда пользователь переходит на лист Бланк для нового заказа список запчастей должен быть заполнен. Проще всего это обеспечить с помощью процедуры выполняемой при активизации листа, которая представлена на листинге 3.3. Заметим, что в ней предполагается, что значения для свойства Name

выбрано Spk1.

Листинг 3.3. Процедура выполняемая при активизации листа

Private Sub Worksheet_Activate()

Spk1.Clear

N = 0

While Worksheets("Номенклатура").Cells(N + 2, 1).Value <> ""

N = N + 1

Wend

For i = 1 To N

Spk1.AddItem Worksheets("Номенклатура").Cells(i + 1, 1).Value + _

" " + Worksheets("Номенклатура").Cells(i + 1, 2).Value + " " + _

CStr(Worksheets("Номенклатура").Cells(i + 1, 3).Value) + " руб."

Next

End Sub

Процедура заполнения списка запчастей достаточна стандартна и не требует комментария. Более интересна следующая (листинг 3.4), которая обеспечивает обработку щелчка по кнопке Включить.

Листинг 3.4. Процедура обработки щелчка по кнопке Включить.

Private Sub CommandButton1_Click()

nom = Spk1.ListIndex

N = 0

While Cells(N + 11, 1).Value <> ""

N = N + 1

Wend

Cells(N + 11, 1) = _

Worksheets("Номенклатура").Cells(Spk1.ListIndex + 2, 1)

Cells(N + 11, 2) = _

Worksheets("Номенклатура").Cells(Spk1.ListIndex + 2, 2)

Cells(N + 11, 3) = _

Worksheets("Номенклатура").Cells(Spk1.ListIndex + 2, 3)

Cells(N + 11, 4) = Col. Text

End Sub

В переменную nom заносится номер элемента, который выделен в списке. Далее подсчитывается число уже заполненных позиций в заказе – они располагаются начиная с 11-й строки. Далее в следующую свободную строку заносится очередная запись.

Теперь на очереди следующая процедура (листинг 3.5), связанная с листом Бланк для нового заказа, которая переносит информацию с текущего листа на лист Названия заказов о котом мы уже говорили. В начале процедуры предварительно проверяется – внесена ли информация в ячейку С1. Далее производится поиск заказа с указанным на листе номеров. В случае положительного ответа на этот вопрос процедура возвращает пользователя к работе с листом формирования нового заказа.

В случае уникальности нового номера заказа процедура аккуратно переносит имеющуюся информацию в каталог заказов. Для формирования даты используется стандартная функция Date.

Листинг 3.5. Процедура обработки щелчка по кнопке Включить в список заказов.

Private Sub InputSpk_Click()

VerZakaz = CStr(Range("C1").Value)

If VerZakaz = "" Then

MsgBox ("Поле кода заказа необходимо заполнить")

Exit Sub

End If

nom = 0

While Worksheets("Названия заказов").Cells(nom + 2, 2).Value <> ""

nom = nom + 1

Wend

For i = 1 To nom

CodList = Worksheets("Названия заказов").Cells(i + 1, 1).Value

If CStr(CodList) = VerZakaz Then

MsgBox ("Такой код заказа уже встречался")

Exit Sub

End If

Next

Worksheets("Названия заказов").Cells(N + 2, 1).Value = _

Range("C3").Value

Worksheets("Названия заказов").Cells(N + 2, 2).Value = Date

NDetal = 0

While Cells(NDetal + 11, 2).Value <> ""

nom = nom + 1

Wend

For i = 1 To nom

Worksheets("Названия заказов").Cells(N + 2, 5 + (i - 1) * 2).Value = Cells(i + 10, 1).Value

Worksheets("Названия заказов").Cells(N + 2, 5 + (i - 1) * 2 + 1).Value = Cells(i + 10, 4).Value

Next

End Sub

Таким образом, мы обеспечили удобный механизм внесения информации. Перейдем к отчетам. Один из них показан на рис.3.8. Здесь требуется автоматическое заполнение ячейки листа отводимой для заказчика, а также заполнение адреса, телефона и факса. Табличная часть на рис.3.8 используется в случае, если число позиций в заказе не превышает трех. В противном случае данная табличная часть не заполняется, а создается другой документ Приложение (рис.3.9). Наша задача теперь – обеспечить данные функциональные особенности.

Рис.3.8.

Рис.3.9.

Для заполнения данных отчетов на листе Названия заказов создадим кнопку Создать отчет (рис.3.10). По этой кнопке будет открываться форма, где от пользователя требуется выбрать заказ, по которому требуется напечатать отчет. На рис.3.11 показана данная форма ввода в окне Visual Basic.

Рис.3.10.

Процедура вызываемая по щелчку по кнопке Создать отчет представлена на листинге 3.6. Ее назначение – открыть форму для формирования отчета.

Листинг 3.6. Процедура обработки щелчка по кнопке Создать отчет.

Private Sub CommandButton1_Click()

Zakaz. Show

End Sub

Рис.3.11.

На листинге 3.7 приведена процедура, которая выполняется при активизации формы. Ее назначение заключается в заполнении списка (точнее элемента управления – Поле со списком). Здесь сначала подсчитывается количество заказов уже имеющихся в базе данных. Информация о том – какая фирма его сделала расположена на листе Клиенты. Поэтому для заполнения поля со списком мы обращаемся к информации о клиентах.

Листинг 3.7. Процедура выполняемая при активизации формы

Private Sub UserForm_Activate()

nom = 0

While Worksheets("Названия заказов").Cells(nom + 2, 1).Value <> ""

nom = nom + 1

Wend

Spk1.Clear

For i = 1 To nom

nomfirma = Worksheets("Названия заказов").Cells(i + 1, 3).Value

nfir = 0

While Worksheets("Клиенты").Cells(nfir + 2, 1).Value <> ""

nfir = nfir + 1

Wend

flag = 0

For j = 1 To nfir

If nomfirma = Worksheets("Клиенты").Cells(j + 1, 1).Value Then

Firma = Worksheets("Клиенты").Cells(j + 1, 2).Value

flag = 1

Exit For

End If

Next

If flag = 0 Then

MsgBox "Фирмы с кодом " + CStr(nomfirma) + " нет"

Else

Spk1.AddItem CStr(Worksheets("Названия заказов").Cells(i + 1, _

1).Value) + " " + _

CStr(Worksheets("Названия заказов").Cells(i + 1, 2).Value) + _

" " + _

CStr(Firma)

End If

Next

End Sub

Теперь работа связана с формой представленной на рис.3.12. На Следующая процедура – обработка щелчка по кнопке Заполнить акт и приложение. На листинге 3.8 она приведена рассматриваемая процедура, которая обеспечивает заполнения только листа АКТ.

Рис.3.12.

В зависимости от количества позиций заказа она заполнять или только лист АКТ или параллельно с актом еще и лист приложение. На листинге приведен первоначальный вариант, который приводит к заполнению только акта (в случае небольшого количества заявок).

Листинг 3.8. Процедура обработки щелчка по кнопке Заполнить акт и приложение

Private Sub CommandButton1_Click()

nomzak = Spk1.ListIndex

coldet = 0

While Worksheets("Названия заказов").Cells(nomzak + 2, 5 + coldet * 2).Value <> ""

coldet = coldet + 1

Wend

nprais = 0

While Worksheets("Номенклатура").Cells(nprais + 2, 1).Value <> ""

nprais = nprais + 1

Wend

nfirm = 0

While Worksheets("Клиенты").Cells(nfirm + 2, 1).Value <> ""

nfirm = nfirm + 1

Wend

codfirm = Worksheets("Названия заказов ").Cells(nomzak + 2, _

3).Value

For i = 1 To nfirm

If codfirm = Worksheets("Клиенты ").Cells(i + 1, 1).Value Then

nazv = Worksheets("Клиенты").Cells(i + 1, 2).Value

adr = Worksheets("Клиенты").Cells(i + 1, 3).Value

Tel = Worksheets("Клиенты").Cells(i + 1, 4).Value

Fax = Worksheets("Клиенты").Cells(i + 1, 5).Value

Inn = Worksheets("Клиенты").Cells(i + 1, 6).Value

End If

Next

Worksheets("АКТ").Cells(6, 3).Value = nazv

Worksheets("АКТ").Cells(7, 3).Value = "Адрес:" + adr

Worksheets("АКТ").Cells(8, 3).Value = "Телефон:" + Tel

Worksheets("АКТ").Cells(9, 3).Value = "Факс:" + Fax

If coldet < 4 Then

For i = 1 To coldet

Worksheets("АКТ").Cells(i + 12, 2).Value = _

Worksheets("Названия заказов").Cells(nomzak + 2, _

5 + (i - 1) * 2).Value

For j = 1 To nprais

If CStr(Worksheets("АКТ").Cells(i + 12, 2).Value) = _

CStr(Worksheets("Номенклатура").Cells(j + 1, _

1).Value) Then

nazvanie = CStr(Worksheets("Номенклатура").Cells(j + 1, _

2).Value)

tarif = CStr(Worksheets("Номенклатура").Cells(j + 1, _

3).Value)

Exit For

End If

Next

Worksheets("АКТ ").Cells(i + 12, 3).Value = nazvanie

Worksheets("АКТ").Cells(i + 12, 3).Value = nazvanie

Worksheets("АКТ").Cells(i + 12, 5).Value = _

tarif

Worksheets("АКТ ").Cells(i + 12, 4).Value = _

Worksheets("Названия заказов").Cells(nomzak + 2, _

5 + (i - 1) * 2 + 1).Value

Next

End If

Hide

End Sub

На рис.3.13 приведен заполненный лист АКТ.

Рис.3.13.

Теперь осталось рассмотреть ситуацию, когда в списке число позиций заказа превышает 3. По ранее сформулированному условию в этом случае требуется разнести информацию по двум документам – Акт и Приложение. Процедуру обработки щелка по кпопке мы теперь дополним (листинг 3.9).

Листинг 3.9. Обработка щелчка по кнопке Заполнить акт и приложение

Private Sub CommandButton1_Click()

nomzak = Spk1.ListIndex

coldet = 0

While Worksheets("Названия заказов").Cells(nomzak + 2, 5 + coldet * 2).Value <> ""

coldet = coldet + 1

Wend

nprais = 0

While Worksheets("Номенклатура").Cells(nprais + 2, 1).Value <> ""

nprais = nprais + 1

Wend

nfirm = 0

While Worksheets("Клиенты").Cells(nfirm + 2, 1).Value <> ""

nfirm = nfirm + 1

Wend

codfirm = Worksheets("Названия заказов ").Cells(nomzak + 2, _

3).Value

For i = 1 To nfirm

If codfirm = Worksheets("Клиенты ").Cells(i + 1, 1).Value Then

nazv = Worksheets("Клиенты").Cells(i + 1, 2).Value

adr = Worksheets("Клиенты").Cells(i + 1, 3).Value

Tel = Worksheets("Клиенты").Cells(i + 1, 4).Value

Fax = Worksheets("Клиенты").Cells(i + 1, 5).Value

Inn = Worksheets("Клиенты").Cells(i + 1, 6).Value

End If

Next

Worksheets("АКТ").Cells(6, 3).Value = nazv

Worksheets("АКТ").Cells(7, 3).Value = "Адрес:" + adr

Worksheets("АКТ").Cells(8, 3).Value = "Телефон:" + Tel

Worksheets("АКТ").Cells(9, 3).Value = "Факс:" + Fax

If coldet < 4 Then

For i = 1 To coldet

Worksheets("АКТ").Cells(i + 12, 2).Value = _

Worksheets("Названия заказов").Cells(nomzak + 2, _

5 + (i - 1) * 2).Value

For j = 1 To nprais

If CStr(Worksheets("АКТ").Cells(i + 12, 2).Value) = _

CStr(Worksheets("Номенклатура").Cells(j + 1, _

1).Value) Then

nazvanie = CStr(Worksheets("Номенклатура").Cells(j + 1, _

2).Value)

tarif = CStr(Worksheets("Номенклатура").Cells(j + 1, _

3).Value)

Exit For

End If

Next

Worksheets("АКТ ").Cells(i + 12, 3).Value = nazvanie

Worksheets("АКТ").Cells(i + 12, 3).Value = nazvanie

Worksheets("АКТ").Cells(i + 12, 5).Value = _

tarif

Worksheets("АКТ ").Cells(i + 12, 4).Value = _

Worksheets("Названия заказов").Cells(nomzak + 2, _

5 + (i - 1) * 2 + 1).Value

Next

Else

For i = 1 To coldet

Worksheets("Приложение").Cells(i + 3, 2).Value = _

Worksheets("Названия заказов").Cells(nomzak + 2, _

5 + (i - 1) * 2).Value

For j = 1 To nprais

If CStr(Worksheets("Приложение").Cells(i + 3, 2).Value) = _

CStr(Worksheets("Номенклатура").Cells(j + 1,

1).Value) Then

nazvanie = CStr(Worksheets("Номенклатура").Cells(j + 1, _

2).Value)

tarif = CStr(Worksheets("Номенклатура").Cells(j + 1, _

3).Value)

Exit For

End If

Next

Worksheets("Приложение").Cells(i + 12, 3).Value = nazvanie

Worksheets("Приложение").Cells(i + 12, 3).Value = nazvanie

Worksheets("Приложение").Cells(i + 12, 5).Value = tarif

Worksheets("Приложение").Cells(i + 12, 4).Value = _

Worksheets("Названия заказов").Cells(nomzak + 2, _

5 + (i - 1) * 2 + 1).Value

Next

End If

Hide

End Sub

Рис.3.14.

Рис.3.15.

Автоматизация учета техники

Продолжим тему связанную с фирмой, которая занимается поставкой и ремонтом сложной строительной техники. В данном случае на с будет интересовать именно учет машин. Разработка будет представлять автоматизированную книгу и поэтому начнем работу с ее создания. На рис.3.16 показан первый лист, который содержит данные о моделях техники. Код необходим для обеспечения уникальности модели.

Для внесения новой модели мы воспользуемся формой показанной на рис.3.17. Программно он вызывается с помощью щелчка по кнопке Добавить название номенклатуры.

Рис.3.16.

Листинг 3.10. Обработка щелчка по кнопке Добавить название номенклатуры

Private Sub CommandButton1_Click()

AddMod. Show

End Sub

Рис.3.17.

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

Листинг 3.11. Обработка щелчка по кнопке Добавить модель

Private Sub CommandButton1_Click()

If Cod. Text = "" Then

MsgBox ("Поле код необходимо заполнить")

Exit Sub

End If

If Nazv. Text = "" Then

MsgBox ("Поле названия необходимо заполнить")

Exit Sub

End If

nom = 0

While Worksheets("Модели").Cells(nom + 2, 2).Value <> ""

nom = nom + 1

Wend

For i = 1 To nom

CodList = Worksheets("Модели").Cells(i + 1, 1).Value

If CStr(CodList) = CStr(Cod. Text) Then

MsgBox ("Такой код модели уже встречался")

Exit Sub

End If

Next

Worksheets("Модели").Cells(i + 1, 1).Value = Cod. Text

Worksheets("Модели").Cells(i + 1, 2).Value = Nazv. Text

MsgBox ("Информация внесена")

AddShow. Hide

End Sub

Теперь перейдем к следующему листу (рис.3.18), который будет хранить информацию о номенклатуре.

Рис.3.18.

Щелчком по кнопке Добавить открывается форма (рис.3.19), которая позволяет добавить в перечень номенклатуры еще одну позицию. Первая процедура, которая потребуется выполняется при открытии формы (листинг 3.12).

Листинг 3.12. Процедура выполняемая при активизации формы

Private Sub UserForm_Activate()

nommod = 0

While Worksheets("Модели").Cells(nommod + 2, 1).Value <> ""

nommod = nommod + 1

Wend

Spk1.Clear

For i = 1 To nommod

Spk1.AddItem Worksheets("Модели").Cells(i + 2, 2).Value

Next

End Sub

Таким образом, список моделей заполняется и пользователь, выбрав модель может внести ее серийный номер.

Листинг 3.13. Процедура внесения очередной записи

Private Sub CommandButton1_Click()

nommod = Spk1.ListIndex

kodmodel = Worksheets("Модели").Cells(nommod + 2, 1).Value

NumberSer = SerN. Text

nprais = 0

While Worksheets("Номенклатура").Cells(nprais + 2, 1).Value <> ""

nprais = nprais + 1

Wend

nmod = 0

While Worksheets("Модели").Cells(nmod + 2, 1).Value <> ""

nmod = nmod + 1

Wend

For i = 1 To nprais

If kodmodel = Worksheets("Номенклатура").Cells(i + 1, 1).Value And _

NumberSer= Worksheets("Номенклатура").Cells(i + 1, 2).ValueThen

MsgBox

End If

Next

ide

End Sub