Реферат: Макросы в Super Calc4
ВЕДЕНИЕ В MACRO.
MACRO — этопоследовательность указаний (MACRO — команд), которые могут контролироватьработу таблицы и состояние экрана в SuperCalc4.SuperCalc4 предлагает широкийвыбор MACRO — команд.
ПоследовательностиMACRO — команд выполняют повторяющиеся действия быстро и аккуратно.Они могутбыть как простыми, так и сложными.Вы можете сохранить MACRO внутри какой-тоодной таблицы и использовать её для работы только с этой таблицей.А можетесоздать MACRO в виде отдельного файла на диске и использовать его слюбойтаблицей.
СТРУКТУРА MACRO
Для удобствадальнейшего изложения поясним сначала терминологию SuperCalc4.
Термины Значения.MACRO
.MACRO — команды
.MACRO — клавиши
Макросы
.MACRO — файл
.MACRO — прог-ма
язык пакета SC4
операторы языка MACRO
MACRO — команды, используемые для ввода в действие клавиш, не дающих изоображение на экране.
программа на языке MACRO, для соз-
дания которой используется команда
//Macro,Write.
Результатом выполнения этой коман-
ды является отдельный текстовый
файл, записанный на диск с рсшире-
нием .XQT.Он может быть использо-
ван в любой талице SuperCalc4.
программа на языке MACRO, создан-
ная внутри какой-то одной таблицы
и в ней хранящаяся. Она предназна-
чена для обработки только этой таб.
НАИМЕНОВАНИЕИ ЗАПУСК МАКРОСОВ.
Составленный изязыка MACRO — команд макрос может существовать и работать в двух видах: либокак MACRO-программа, либо MACRO-файл. Для того, чтобы макрос заработал, емунеобходимо дать имя и запустить его.Различают три основные части макросов:
во-первых, команды для выполнения;
во-вторых, метки для выделения отдельных частеймакроса;
в-третьих, комментарии для пояснения каждого шага.
---------------------------------------------------------|
| A || B || C ||
1
2
3
4
5
6
МЕТКИ MACRO-КОМАНДЫ КОММЕНТАРИИ
\chek if D1=3branch \m Если D1=3, то на метку \М
beep Иначе издать гудок
\m let d1,2 Ввод 2 в клетку D1
branch \check Пойти на метку \chek
--------------------------------------------------------------
— 2 -
Для размещениясоставных частей макросов в SuperCalc4 используются три любые последовательныеколонки, например: первая колонка — для меток (колонка A); вторая — дляMACRO-команд (колонка B); третья — для комментариев (колонка C).
Для работынеобходима вторая колонка.Остальные две колонки необязательны, но именно ониделают макрос легким для чтения и загрузки.Вторая (основная) колонка составляетсяиз клеток содержащих текст.Эти клетки называются MACRO-клетками и содержатMACRO-команды.Некоторые MACRO-команды заключаются в фигурные скобки, например:
DOWN,VIEW,CALL.
Некоторые — записываются в таком же виде, как (/)-команды SuperCalc4, если бы вы выполнялиих набором первых букв команд, например:
/GB — снятие бордюра;
/OPGQ — выод на печать.
Все символы в SuperCalc4(буквы, числа, знаки препинания) вводятся с клавиатуры, т.е. просто нажатиемсоответствующей клавиши.Исключение составляют символы и ~, которые при вводев макрос необходимо заключить в фигурные скобки: и ~.Для клавиш, не дающихизоображение на экране, используются их названия.MACRO-команды, используемые дляввода в действие таких клавиш называются MACRO-клавишами.
НАИМЕНОВАНИЕИ ЗАПУСК МАКРОСОВ
Составленный из MACRO-команд макрос можетсуществовать и работать в двух видах: либо как MACRO-программа, либо какMACRO-файл.Для того, чтобы макрос заработал, ему необходимо дать имя и запуститьего.
MACRO-программа.
Для присвоения имениMACRO-программе используется команда /Name,Create.Имя даётся первой клеткепрограммы.Признаком конца программы является пустая клетка.Такимобразом, начало программы задаёт пользователь, а конец определяет SuperCalc4.ИмяMACRO-программы может быть любым.Но для ускорения вызова MACRO-программы её имядолжно быть одиночной буквой, которой предшествует (\)-Backslash.Например, еслидать программе имя \R, то запуск программы будет осуществляться нажатием клавиш<ALT>-<R>.
ЗапускMACRO-программы может быть осуществлён двумя способами:
ВАРИАНТ 1.
Нажмите<ALT>-<F5> или <ALT>-<=>, затем в строке ввода наберитеимя MACRO-программы.Например, для запуска MACRO-программы с именем TABEL нажмитеодновременно <ALT>-<F5>, затем введите TABEL и нажмите<ENTER>.А можно просто нажать <ALT>-<F5>, подвести курсор впервую клетку MACRO-программы и нажать <ENTER>.
ВАРИАНТ 2.
Если вы далиMACRO-программе название с помощью \ и буквы, её можно запустить одновременнонажатием клавиши <ALT> и соответствующей буквы.
— 3 -
MACRO-файл.
Для работы с MACRO-файлами существует комманда//Macro.
Набрав всроке ввода //Macro, вы попадёте в меню:
--------------------------------------------------------|
| A || B || C || D || E || F || G || H ||
-------------------------------------------------------------|
| 1 | |
| . | |
| . | |
| 19 | |
| 20 | |
------ |
| ->A1 | LearnRead Write eXeute | 9>//Macro, | MENU Define learn Range (ALT-F4 to enable)|
--------------------------------------------------------------
Описание опций команды //Macro
I Learn — определяет дипазон клеток для режима LEARN.
II Read — загружаетMACRO-файл в указанное место в таблице По умолчанию MACRO-файлы имеютрасширение .XQT.
После ввода имени файла и диапазона клетокдля его загрузки в PROMPT-строке появится меню:
--------------------------------------------------------|
| A || B || C || D || E || F || G || H ||
-------------------------------------------------------------|
| 1 | |
| . | |
| . | |
| 19 | |
| 20 | |
------ |
| ->A1 |
All Macros-Only Labels-Macros Comment-Macros |
22>//Macro,Read,W,A3:C9, |
MENU Read/Write macros, labels and comments |
--------------------------------------------------------------
Значения опций этого шага:
All — загружает весьMACRO-файл, располагая метки слева от основного диапазона, а комментариисправа.Колонка A не может быть использована для основного диапазона.
Macros-Only — загружает только MACRO-команды в основной диапазон.
Labels-Macros — загружает только метки иMACRO-команды.
Comment-Macros — загружает толькоMACRO-команды и комментарии.
III Write — записывает указанный диапазонклеток в файл на диск с расширением .XQT.Если файл с таким именем существует,то SuperCalc4 в PROMPT-строке предложит :Change, Backup, Overwrite.
— 4 -
--------------------------------------------------------|| A || B || C || D || E || F || G || H ||
-------------------------------------------------------------|| 1 | | |. | | |. | | | 19 | | | 20 | |
------ |
| ->A1 |
Change Backup Overwrite |
20>//Macro,Write,W.XQT |
MENU File exists: Change name on disk |
--------------------------------------------------------------
Ниже приведены значения опций этого шага:
Change — позволяет изменить илиотредактировать имя файла. Backup — записвает на диск два файла: найденный срасширением BAK; новый с расширением XQT
Overwrite — полностью перписывает старыйфайл на новый. После вода имени файла и диапазона клеток для его за-
писив PROMPT-строке появится меню:
--------------------------------------------------------|
| A || B || C || D || E || F || G || H ||
-------------------------------------------------------------|
| 1 | |
| . | |
| . | |
| 19 | |
| 20 | |
------ |
| ->A1 |
All Macros-Only Labels-Macros Comment-Macros |
23>//Macro,Write,W,A3:C9, |
MENU Read/Write macros, labels and comments |
--------------------------------------------------------------
Ниже приведены значения опций этого шага:
All — запишет весь MACRO-файл, располагаяметки слева от основного диапазона, а комментарии справа.Колонка A не можетбыть использована для основного диапазона.
Macros-Only — запишет только MACRO-команды в основной диапазон.
Labels-Macros — запишет только метки и MACRO-команды.
Comment-Macros — запишет толькоMACRO-команды и комментарии.
IVExecute — запуск MACRO-файла из таблицы.
Autoexec — Macro.
Вам может потребоваться, чтобыMACRO-программа автоматически запускалась призагрузке таблицы.Для этого дайтеей название: \AUTOEXEC.
Для автоматическгозапуска MACRO-файла призапуске пакета SuperCalc4, надо дать ему имяAUTOEXEC.XQT.
— 5 —
MACRO-РЕЖИМЫ
В SuperCalc4 существует три MACRO-режимаработы, которые приведены в таблице :
Режим Включение/выключениеSTEP
LEARN
DIREСT
<ALT>
<ALT>
<ALT>
<F2>
<F4>
<F6>
Служебный вид панели экрана при работережимов MACRO,STEP,LEARN,DIRECT:
->B2
With:
1>
READY
9 Memory: 379 Last Col/Row:K2
F1:Help F3:Names Ctrl-Break:Chanel
MACRO-----
->A1
With:
1>
READY
-----------------------------------------
9 Memory: 379 Last Col/Row:A1
F1:Help F3:Names Ctrl-Break:Chanel
------------
STEP
-----
->A1
With:
1>
READY
-----------------------------------------
9 Memory: 379 Last Col/Row:A1
F1:Help F3:Names Ctrl-Break:Chanel
------------
LEARN
-----
->A1
With:
1>
EDIT
-----
-----------------------------------------
9 Memory: 379 Last Col/Row:A1
F1:Help F3:Names Ctrl-Break:Chanel
-----------------------------------------
------------
DIRECT
------------
Использование STEP-режима.Включив STEP-режим, вы можете следить заходом выполнения макроса от оператора к оператору(пошагово).
Вид служебной панели при выполнении макроса в этом режиме:
------------------------------------------------------------
->B2 Text=«SUSPEND
With: 9 Memory: 379 Last Col/Row:B3
1>
READYF1:Help F3:Names Ctrl-Break:Chanel F8:STEP4/0@B1/1
------------------------------------------------------------
— 6 -
В INDICATOR -части строки появляется подсказка:
F8:STEP — x/y
Здесь координаты x/y обозначают ряд иномер позиции символа в исполняемой MACRO-команде. При работе макроса в такомрежиме перход от действия к действию происходит при нажатии клавиш F8.Послевыполнения MACRO-команды вы можете пользоваться стрелками для движению поэкрану и делать все необходимые изменения, но прежде, чем нажать клавишу F8,верните курсор на исходную позицию.Схема работы STEP-режима показана втаблице:
Действие Клавиши1.Вход в режим
2.Переход от одной MACRO-команды к другой
3.Выход из режима
<ALT>-<F2>
<F8>
<ALT>-<F2>
Использование LERAN-режима.
LEARN-режим обепечивает автоматическуюзапись каждой нажатой вами клавиши в определённом месте таблицы в видеMACRO-команды.Схема работы LEARN-режима:
Действие Набор клавиш1.Ввод границ дипазона, в котором вы будете размещать текст макроса.
2.Вход в режим.
3.Выполнение операций, предназначенных для описания в макросе.
4.Временный выход из режима LEARN: а)переход в DIRECT-режим б)ввод в макрос текста с
клавиатуры
в)возврат в LEARN-режим
5.Выход из режима
//Macro,Learn,<диапазон>
<ALT>-<F4>
<ALT>-<F6>
<ALT>-<F6>
<ALT>-<F4>
Теперь вам остаётсядать имя макросу и запусть его в работу.Так можно создать как MACRO-программу, так и MACRO- файл
Использование DIRECT-режима.
Этот режим используется каквспомогательный режим для времееного выхода из LEARN-режима.Он задаётся толькоиз режима LEARN, и в нём команды не выполняются.
ОПИСАНИЕMACRO-КОМАНД.
Все существующиеMACRO-команды SuperCalc4 можно разделить на три вида: экранные, управляющие иMACRO-команды для ввода данных.
— 7 -
Экранные MACRO-команды.
SuperCalc4 даёт возможность с помщьюMACRO-команд контролировать вид служебной панели и подачу компьютером звуковыхсигналов.Для этого используются 12 MACRO-команд, которые приведены в таблице:
MACRO команда Значение1.BEEP x
2.INDICATOR „текст“
3.MACROPROMPT „текст“
4.MESSAGE „текст“
5.PROMPT „текст“
6.STATUS „текст“
7.PANELOFF
8.PANELON
9.ENTRYOFF 10.ENTRYON
11.WINDOWSOFF
12.WINDOWSON
Звуковой сигнал, повторяющийся x раз
Замена INDICATOR в строке
HELP на заданный текст (до 5 символов)
Замена MACROPROMPT в строке
HELЗ на заданный текст (до 18 символов)
Замена MESSAGE в строке HELP на заданный текст (до 49 символов)
Контроль строки PROMPT
Контроль строки STATUS
Блокировка строки ENRTY, фиксация изоображения в других строках служебной панели
Восстановление нормальной функции всех строк служебной панели
Очистка строки ENTRY
Восстановление нормальной функции строки ENTRY
Блокировка динамического отображения окна таблицы
Восстановление нормальной функции отображения окна таблицы
Управляющие MACRO-команды.
SuperCalc4 включает MACRO-командыуправления, позволяющие составлять макросы из различных типов логическихконструкций (последовательных, циклических, ветвление), а также MACRO-команды,полностью контролирующие процесс обработки электронной таблицы.Все управлящиеMACRO-команды приведены в таблице:
MACRO команда Значение1.BRANCH xx
2.BREAKOFF
3.BREAKON
4.CALL xx x1,x2...
Переход выполнения макроса на указанную метку xx
Отменяет возможность прерывания макроса по команде <CTRL>-<BREAK>
Включает возможность прерывания макроса по команде <CTRL>-<BREAK>
Переход выполнения макроса на
— 8 -
MACRO команда Значение5.COMMENT „текст“
6.DEFINE клетки
7.DELAY T
8.DISPATCH xx
9.IF условие 10.LABEL xx 11.LET клетка,xx
12.MENU xx
13.QUIT
14.RESTART
15.RETURN
метку xx (с возвратом и пере-
дачей параметров x1,x2...
Ввод комментариев в текст макроса
Ввод аргументов, переданных командой CALL, в заданные клетки
Прерывание процесса макроса на число секунд указанное в T Продолжение макроса с клетки, указанной в xx
Условный оператор
Метки в MACRO-файлах
Ввод переменных или выражений (xx) в указанную клетку
Оператор, обозначающий начало функции МЕНЮ
Прерывание макроса
Отмена всех „возвратов“, определёнными CALL
Возврат выполнения команде, следующей за командой CALL
MACRO-команды для ввода данных.
MACRO-команды этоговида реализуют в SuperCalc4 ввод данных пользователемв интерактивномрежиме.Сюда также относятся так называемые вспомогательные команды, контролирующиеработу режима ВСТАВКА и процесс записи файлов на диск.
Всеони приведены в таблице:
MACRO команда Значение1.?
2.SUSPEND
3.KEY
4.GET адрес
5.GETCELLS текст, адрес
6.GETCOLS текст, адрес
7.GETKEY текст, адрес
8.GETNUMBERтекст, адрес
9.GETROWS текст, адрес 10.GETTEXT текст, адрес 11.INSERTOFF 12.INSERTON 13., 14.BACKUP 15.OVERWRITE
Приостановка выполнения макроса:
до нажатия клавиши <ENTER>
до нажатия клавиши <F8>
до нажатия любой клавиши
до введения по адресу:
-записи, с клавиатуры
-диапазона клеток
-диапозона столбцов
-любой клавиши
-числа
-номера строки
-текста
Выключение режима ВСТАВКА
Включение режима ВСТАВКА
Всавка в текст фигурной скобки
Создание BACKUP-файла
Презапись файла
— 9 —
ПРИМЕР
Если мы напротяжении какого- то время ни работаем с определённой таблицей, то каждый разпри загрузке SuperCalc4 нам приходятся выполнять ряд действий для загрузкинашей таблицы (например, EXAMPLE.CAL). Это задание можно упрастить с помощьюMACRO-команд.
Для этого создадимMACRO-файл с именем L.XQT (от слова Load), который и будет загружать даннуютаблицу.Выполним ряд команд:
1.Войдём в SuperCalc4 запуском файла SC4.COM
2.Выберем меню //Macro,Learn
3.Затем введём диапазон клеток (например столвец B)
4.Нажатием <ALT>-<F4>, войдём в режим LEARN
5.Далее выполняемдействия, которые хотим поместить в MACRO-файл ( </> <L>EXAMPLE.CAL <ENTER> <A> — для /Load,Example.CAL,All )
6.Выйдем из режима LEARN нажатием<ALT>-<F4>
7.Для удобства в клетку С1 введёмкооментарии, а в A1-метки. Установим необходимую ширину для удоства чтения.
Еслимы сдела ли всё правильно, то на экране увидим:
| A | B || C ||1 |
2 |
3 |
. |
. |
19 |
20 |
МЕТКИ
\L
MACRO-КОМАНДЫ /LExample.CAL~AКОММЕНТАРИИ |
;Load,Example.CAL,All |
|
|
|
|
|
->A1 Text=»\L |
With: 7 Memory: 379 Last Col/Row:C2 |
1> |
READY F1:Help F3:Names Ctrl-Break:Chanel |
|
—
8.Запишем MACRO-команды командой //Macro,Write,L,B,All
9.Теперь мы можем наш MACRO-файл L.XQTзапустить, нажатием клавиш <ALT>-<L>.
Если необходимочтобы EXAMPLE.CAL загружалась всегда после запуска SuperCalc4, нужно толькопереименовать L.XQT в AUTOEXEC.XQT
— 10 —
ИСПОЛЬЗУЕМАЯЛИТЕРАТУРА:
* Черемных О.С. «SuperCalc 4 и 5 — руководство подьзователя» — М.,1992
* Литвин О.Ф. «Табличный процессорSuperCalc4.»
М.: Финансыи статистика, ЮНИТИ, 1991
* Рыжкова М.Ю., Миргалиев И.А., Казакова И.И.
«SuperCalc4.Основы организации и методыработы» — М.:
«КОМЭК»,1992
* Дойл У. «Табличный процессор SuperCalc для
персонального компьютера.» — М.: Финансы истатистика,
1987
_