Учет квартплаты (АРМ бухгалтера-расчетчика)

Автор работы: Пользователь скрыл имя, 23 Апреля 2013 в 18:48, контрольная работа

Описание работы

Предприятие имеет развитую инфраструктуру по обеспечению предприятий и организаций и жилых микрорайонов следующими видами услуг:
установка телефонов и обеспечение телефонной связью
передача электроэнергии через собственную подстанцию
снабжение паром, холодной и горячей водой от собственных источников (ТЭЦ, водозабор)
перевозка нефтепродуктов автотранспортом.

Файлы: 1 файл

АРМ бухгалтера.docx

— 135.40 Кб (Скачать файл)

Если выбран пункт “Выйти”, то в процедуре INS_ST закрывается окно и деактивируется меню.

“СЕРВИС”-“Нормы оплаты услуг”

Данный пункт открывает  окно M_ZAR, где с помощью команд @…SAY…GET (см. прилож. 1.4 стр. 4) выводятся  переменные ставок, определенные в  начале программы в файле MENI.PRG и  после их редактирования они сохраняются  в файле M_ZAR.MEM. чтобы их сохранить  необходимо выйти из окна по кнопке “Сохранить”, которая запустит процедуру  сохранения (см. прилож. 1.2 стр. 20).

“СЕРВИС”-“Упаковка данных” 

Выбор этого пункта запускает  процедуру физического удаления данных, помеченных ранее на удаление (см. прилож. 1.2 стр. 22). В первых строках  сканируются записи, помеченные на удаление в БД жильцов и помечаются записи во вспомогательной БД ставок, которая связана с основной БД по полю табельного номера (TAB). Затем  снова сканируется БД жильцов  с целью проверки недопущения  наличия жильцов без плательщика. Здесь перебираются помеченные записи, и в переменные заносятся значения адреса для поиска, и фамилии для  возможного предупреждения.

После этого ищется жильцы, проживающие по этому адресу, если такие существуют, то ищется плательщик и если такого нет выводится окно, показанное на рисунке, где нужно  выбрать одно из трех действий (см. прилож. 1.2 стр. 23, процедура D_IN).

“Удалить всех” – будут  помечены все записи по этому адресу.

“Изменить” – запустится процедура изменения, для найденного жильца.

“Восстановить” - восстановить плательщика, ранее помеченного  на удаление, то есть снимет пометку  командой RECALL.

“СЕРВИС”-“Переиндексация”

В этой команде я не пользовался  командой REINDEX, а просто удалял все  индексы и создавал новые. Это  и проще и времени уходит меньше (см. прилож. 1.2 стр. 23). В первых строках  закрываются все БД и вместе с  ними структурные индексы, далее  с помощью команды DOS удаляются  все файлы, имеющие расширение .CDX то есть структурные индексы, потому что другие индексы в программе  не используются, и затем выполняется  процедура открытия баз данных (см. прилож. 1.3), где индексы создаются  автоматически. Здесь нужно сказать, что при таком подходе FoxPro может  выдать ошибку, и требование явно указать  на БД, которую нужно открыть. Эта  проблема решается с помощью функции ON ERROR DO EROR WITH ERROR(), которая передает код ошибки в процедуру EROR как  параметр (см. прилож. 1.2 стр. 53), и в  ней в зависимости от области  открываются нужные базы данных.

Пункт меню – “КАДРЫ” 

После того как в базе жильцов  имеются записи, можно работать с  процедурами, осуществляющих действия по их обработке. Эти процедуры в  основном находятся в первом пункте меню “КАДРЫ”.

“КАДРЫ”-“Работа с картотекой” 

При выборе данного пункта открывается окно, представленное как  личная карточка жильца, в которой  отображается необходимая информация и средства по ее обработке (см. прилож. 1.2 стр. 1-20).

Как уже описывалось в  главе 2 с работой в этом окне, вся информация, расположенная в  этом окне делится на две части, поэтому  каждую часть разберем по отдельности. Но прежде рассмотрим заполнение окна информацией и другими объектами (см. прилож. 1.2 стр. 1-2 и прилож. 2 рис. 2 ).

Итак в первых строках  выполняются некоторые технические  действия, а именно это проверка наличия данных, которая описывалась  выше, определение и присвоение переменным “e” и ”b” логических значений для анализа конца и начала БД, и в зависимости от этого  доступность или недоступность  кнопок перемещения, клавише F1 назначается  процедура открытия соответствующего окна с помощью, клавише F5 процедура  поиска. После этого активируется окно INS и в него выводится следующая  информация: это поля БД, имеющие  символьные и числовые данные с помощью  команды GET с опцией, запрещающей  редактирование. Это поля фамилии (FAM), табельного номера (TAB), телефона (TEL), адреса (YL,DOM,KW_RA), квадратных метров (KV_M), суммы  начисленной квартплаты из БД, в  которой хранятся все начисления, и доступные для редактирования GET-поля количества (KOL_VO), код и описание льготы из БД льгот, периода действия льготы (DAT_C,DAT_PO) и поля выбора услуг, имеющие логические значения, представленные с помощью переменных: kw (KW_L)-квартплата, gw (G_W_L)-горячая вода, xw (X_W_L)-холодная вода, ks (K_YS_L)-коммунальные услуги, ot (OTOP_L)-отопление, elc (EL_C_L)-електричество, tl (TEL_L)-телефон, rd (RAD_L)-радио, которые затем выводятся  на экран с помощью GET-объектов (кнопки-переключатели). А также другие GET-объекты, которые  будут рассмотренны позже.

Далее идут SAY-объекты, это  подписи к GET-полям, а также результаты возвращаемые функциями, которые выводятся  с помощью выполнения функции POS_CH1 (=POS_CH1( )) (см.прилож. 1.2 стр.3). разберем только выводимые значения, возвращаемые функциями.

Количество жильцов –  выполняется функция KOL (прилож. 1.2 стр. 19), где путем сканирования формируется  переменная k и возвращается ее значение (RETURN k), так как эта переменная числового типа, а команда SAY выводит  только символьный тип данных, то необходимо преобразовать числовой тип в  символьный и убрать первые пробелы, что позволяет следующие команды: LTRIM(STR(KOL(0))), где KOL(0) – полученное значение, STR – функция преобразования числовых данных в символьные, LTRIM – удаление ведущих пробелов.

Количество льготников –  аналогичная функция, описанная  выше только считает жильцов, если поле LGOT имеет значение истины (.Т.).

Ставки по которым производится расчет для данного жильца. (см. прилож. 1.2 стр 16-17). Здесь сначала проверяется  поле ставок БД ставок, так как связь  одна ко многим то при перемещении  курсора в основной базе он перемещается во всех вспомогательных базах и  если поле в БД равно нулю, то параметру, который является результатом работы функции, присваивается значения нормативной  ставки, иначе значения этого поля. Затем в команде SAY тип возвращаемого  результата преобразуется в символьную форму и после вывода их на экран  они накрываются невидимыми кнопками.

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

И в этой же процедуре раскрашиваются области внутри окна, для их более  выразительности и выделения. (@ … FILL TO …).

Также необходимость заполнения окна с помощью выполнения функции  вызвано тем, что информация по каждому  жильцу является не всегда одинаковой, в окне предусмотрено перемещение  по БД, а значит и обновление выводимой  информации. Это достигается с  помощью этой функции и опции  обновления GET-объектов SHOW <имя процедуры>, которая входит в команду READ, которая  будет рассмотрена ниже.

Вернемся к окну. Как  уже описывалось выше (глава 2 стр. 26) вся основная информация о жильце содержится в первой части. Рассмотрим работу доступных GET-объектов в этой части.

Первый GET-объект это поле количества проживающих (@ 5,39 GET kol_vo), при  зтом как бы для проверки рядом  выводится SAY-объект количества, рассчитанный программным путем (см. выше).

Далее SAY-объект “СОСТАВ СЕМЬИ” накрыт невидимой кнопкой (@ 6,27 GET family FUNCTION ‘*I ‘ VALID FAMILY( ) …).Невидимой она  называется потому, что не формируют  никаких текстовых сообщений  и только выделяются цветом, и при  нажатии клавиш Ehter/Space могут вызывать функцию через опцию VALID. Здесь  при нажатии этих клавиш происходит процедура FAMILY (прилож. 1.2 стр. 8) в которой  в переменные заносятся данные о  текущем TAG’e, и адресе, устанавливается  фильтр доступа к данным, имеющим  этот адрес и активируется меню, из полей БД жильцов, которое определено ранее в файле-процедуре MENI (прилож. 1.1) и пункты которого состоят из фамилии и двух вспомогательных  полей, указывающих на категорию  жильцов (плательщик, льготник). Выбор  пункта этого меню отобразит в  окне этого жильца и обновится  информация относительно этого жильца, также в зависимости от категории  жильца переменной _FILTR присваивается  значение 1-если жилец является плательщиком, 2- если льготник и 3- если ни тот ни другой (просто проживающий). Это нужно для  того, чтобы при выполнении процедуры  обновления (SHOW) в зависимости от значения этой переменной, будет установлен соответствующий TAG, влияющий на предъявление данных.

Следующая группа GET-объектов выводит поля выбора услуг с помощью  кнопок-перек-лючателей (@ 10-17,2 GET kw(gw,xw,ks,ot,elc,tl,rd) FUNCTION ‘*C <имя услуги> ‘VALID KW( )(GW(),XW()…)). Здесь переменные и поля имеют  один и тот же тип данных, а  именно логический и в процедурах, вызываемых при выходе по опции VALID просто полю присваивается значение переменной (см. прилож. 1.2 стр. 17-18).

Чуть иначе обстоит  дела с выбором телефона и радио. Это сделано для того, что предполагается, что в квартире установлена одна телефонная и(или) одна радиоточка, поэтому  если в квартире живут два или  более льготников, которые пользуются льготными ставками на эти услуги, то при расчете им обоим (или более) будет убавляться плата по этим услугам, что в конечном итого телефон  и(или) радио будет бесплатно или  ЖКХ еще будет доплачивать  за пользование этими услугами, что  разумеется недопустимо, вот для  этого осуществляется контроль выбора услуг. По своему содержанию процедуры  одинаковы, поэтому разберем одну из них (см. прилож. 1.2 стр. 18).

Итак при выборе телефона (радио) вызывается процедура TL1(RD1) в  которую передаются три параметра: 1-OR_R (OR-в процедуре), 2-LGOT (LG-в процедуре), которые имеют значения полей  плательщика (0,1) и льготы (.T.,.F.), относительно жильца которому выбирают услугу, 3-RECNO( ) (R-в процедуре), который имеет  значение номера записи в БД этого  жильца и 4-ORDER( ) (ORD-в процедуре), который  имеет символьное значение активного  индекса (TAG’a). Далее в процедуре  в переменные заносятся значения адреса, для включения их в SCAN-условие, а также, только для телефона, в  условие поиска, где ищется плательщик и у него проверяется поле телефона и если оно пустое, то предполагается, что телефона нет и выбрать  эту услугу невозможно.

После этого в структуре DO CASE анализируются переданные параметры:

CASE OR=1.AND.LG=.T. то есть если  это плательщик и он также  льготник. В первой строке активируется TAG, при котором доступны все  записи в БД, затем сканируется  БД и у всех жильцов, имеющих  этот адрес полю выбора телефона(радио)  присваивается значение “Ложь” (.F.) и затем этому жильцу полю  выбора телефона(радио) присваивается  значение “Истина” (.Т.). то есть  по этому условию плательщик  имеющий льготу имеет преимущество  перед другими жильцами, имеющими  льготу, по выбору этих услуг. 

CASE OR=1.AND.LG=.F. то есть если  это плательщик, не имеющий льготу. Здесь просто полю выбора телефона(радио)  присваивается значение “Истина”.

CASE OR=0.AND.LG=.T. то есть если  это не плательщик, а льготник. В этом случае сканируются  записи, имеющие этот адрес и  льготу, и если у кого-либо поле  выбора телефона(радио) имеет  значение “истины”, то переменной TL(GET-объект) присваивается значение  “Ложь” и после завершения  сканирования значение переменной  присваисвается полю выбора телефона(радио).

Следующие GET-объекты, это  группа невидимых кнопок, которые  накрывают области, где выводятся  значения стоимости услуг (@ 10,28 GET tar_s FUNCTION ‘*I ;;;;;;;’ VALID TARIFS( )…), при выборе которых выполняется процедура TARIFS (см. прилож. 1.2 стр. 11, прилож. 2 рис. 3), где  можно выбрать тарифную ставку для  услуги на которой был сделан выбор, из имеющихся в БД тарифов или  если нет, то добавить. При этом можно  установить эту ставку всем жильцам  дома, или можно установить норматив по этой услуге жильцу или всему  дому. Работа, в окне и с меню во многом схожа с работой описанной  ранее, при описании “СЕРВИС”-“Тарифы”. Рассмотрим отличия. В первых строках  определяется окно и меню для работы процедуры.

Далее с помощью структуры DO CASE определяется на какой услуге был  сделан выбор, и в зависимости  от этого устанавливается ограничение  на предъявление данных, например если это горячая вода, то появятся тарифы, имеющие значение .Т. поля K_CH, (расчет на одного человека) и наоборот, переменной VIB_STAVOK присваивается имя поля в  БД ставок, для того, что в дальнейшем с помощью макроподстановки (&VIB_STAVOK) этим полям будут присвоены соответствующие  значения. И после этого активируется окно и меню для выбора ставки по этой услуге, при этом в правом углу появляется системное окно-подсказка, с помощью команды WAIT, с текстом  выбранной услугой.

Пункт “Выбрать” предъявляет POPUP-меню с BAR-пунктами, состоящими из полей  БД тарифов, и при выборе любого пункта появляется меню с выбором установить всем жильцам дома или квартиры. После этого в процедуре V_ST1 куда передаются параметры номера BAR-пункта (BAR( )) и номера текущей записи в  БД (RECNO( )) (см. прилож. 1.2 стр.14-15). Здесь  в структуре DO CASE определяется номер  выбранного BAR-пункта и для всех жильцов  дома (параметр=1(“Установить всем жильцам  дома”) или для данных жильцов  квартиры (параметр=2 “Установить данному  жильцу”), в скан- условии, полям  БД ставок этих жильцов по выбранной  услуге присваивается значения, которые  имеются в поле ST_KA в БД тарифов (REPLACE &VIB_STAVOK WITH ST, где VIB_STAVOK-это имя  поля в БД ставок (см. выше) ST-ставка из поля ST_KA в БД тарифов (ST=ST_KA))

Здесь также добавлен повый  пункт меню “Установить норматив”, при выборе которого появляется POPUP-меню с двумя BAR-пунктами “Установить  всем жильцам дома” и “Установить  данному жильцу” выбор этих пунктов  осуществляется в процедуре V_ST2 куда передаются параметры номера BAR-пункта (BAR( )) (см. прилож. 1.2 стр.15). Здесь в  структуре DO CASE определяется номер  выбранного BAR-пункта и для всех жильцов  дома (параметр=1(“Установить всем жильцам  дома”) или для данных жильцов  квартиры (параметр=2 “Установить данному  жильцу”), в скан- условии, полям  БД ставок этих жильцов по выбранной  услуге присваивается нулевые значения.

Последние GET-объекты в  этой части экрана это кнопки “По  льготе” и “По оплате”, которые  доступны если жилец является плательщиком (“По оплате”) и(или) льготником (“По  льготе”).

Кнопка “По льготе”  – открывает окно (см. прилож. 2 рис 5), в котором с помощью команды @…SAY…GET, выводятся поля из базы льгот, по тому коду, который имеет данный жилец, доступные для редактирования. (см. прилож. 1.2 стр. 9).

Кнопка “По оплате”  – открывает окно (см. прилож. 2 стр. 6), в котором с помощью команды @…SAY…GET, выводятся поля из базы ставок для данного жильца, доступные  для редактирования (см. прилож. 1.2 стр.10). при этом после закрытия этого  окна или после выхода из последнего (первого) GET-объекта все значения полей заносятся в переменные, появляется это же окно с информацией  о количестве квартир в доме, по адресу которому живет плательщик, и с помощью команды WAIT будет  предложено установить такие ставки всем жильцам дома (WAIT ‘Установить  всем жильцам (Y/N)’ TO Y ) и если будет  нажата клавиша Y (Н), то с помощью  фильтра и сканирования эти ставки будут присвоены всем жильцам, проживающих  по этой улице и дому, иначе только жильцам данной квартиры. Это достигается  с помощью команды REPLACE <имя поля> WITH <имя переменной>, так как  связь одна ко многим, то перемещения  указателя в основной БД вызывает перемещение во вспомогательной.

Информация о работе Учет квартплаты (АРМ бухгалтера-расчетчика)