UNIFOR — различия между версиями
Sokv (обсуждение | вклад) (→Функции, не вошедшие в другие категории) |
Sokv (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
+ | UNIFOR – программная функция (также говорят ''формат-программа'' или ''форматный выход''), предназначенная для вызова из [[Язык форматирования системы ИРБИС#Понятие формата|форматов]]. UNIFOR реализует выполнение таких операций по форматированию, которые не могут быть выполнены с помощью собственно [[Язык форматирования системы ИРБИС|языка форматирования]]. | ||
+ | |||
+ | ==Использование UNIFOR== | ||
+ | |||
+ | Обращение к программной функции UNIFOR в формате производится в полной или сокращённой форме: | ||
+ | &unifor(формат) | ||
+ | &uf(формат) | ||
+ | где: | ||
+ | * '''<tt>&</tt>''' – идентификатор вызова формат-программы; | ||
+ | * '''<tt>unifor</tt>''' – имя формат-программы (соответственно '''<tt>uf</tt>''' – сокращённое имя формат-программы); | ||
+ | * '''<tt>формат</tt>''' – аргумент. | ||
+ | |||
+ | Рекомендуется использовать сокращённую форму вызова программной функции UNIFOR. Сокращённая форма по действию ничем не отличается от полной формы, зато позволяет сократить размер формата и повысить его читаемость. | ||
+ | |||
+ | Вид реализуемой функции определяется первыми символами строки, которая формируется в результате выполнения формата, передаваемого в качестве аргумента формат-программы. | ||
+ | |||
==Перечень функций формат-программы UNIFOR с примерами их применения== | ==Перечень функций формат-программы UNIFOR с примерами их применения== | ||
Строка 19: | Строка 35: | ||
EN<строка> | EN<строка> | ||
− | где <tt>N</tt> | + | где <tt>N</tt> – количество слов (одна цифра). |
Строка 31: | Строка 47: | ||
FN<строка> | FN<строка> | ||
− | где <tt>N</tt> | + | где <tt>N</tt> – количество слов (одна цифра). |
'''Примеры:''' | '''Примеры:''' | ||
Строка 44: | Строка 60: | ||
где: | где: | ||
* N=0 если ДО заданного символа (не включая его); N=1 если начиная С заданного символа (включая его). | * N=0 если ДО заданного символа (не включая его); N=1 если начиная С заданного символа (включая его). | ||
− | * А | + | * А – заданный символ (# – обозначает цифру; $ – обозначает букву). |
'''Примеры:''' | '''Примеры:''' | ||
Строка 56: | Строка 72: | ||
TN<строка> | TN<строка> | ||
− | где N | + | где N – вид таблицы транслитерации (0 или 1). |
'''Примеры:''' | '''Примеры:''' | ||
Строка 89: | Строка 105: | ||
'''Примеры:''' | '''Примеры:''' | ||
− | &unifor( | + | &unifor('+3E',v1007) |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
Строка 107: | Строка 123: | ||
Имеются следующие подфункции: | Имеются следующие подфункции: | ||
− | * '''<tt>3</tt>''' | + | * '''<tt>3</tt>''' – выдать текущую дату в виде ГГГГММДД. |
− | * '''<tt>30</tt>''' | + | * '''<tt>30</tt>''' – выдать текущий год в виде ГГГГ. |
− | * '''<tt>31</tt>''' | + | * '''<tt>31</tt>''' – выдать текущий месяц в виде ММ (с лидирующим нулем). |
− | * '''<tt>32</tt>''' | + | * '''<tt>32</tt>''' – выдать текущий день в виде ДД (с лидирующим нулем). |
− | * '''<tt>33</tt>''' | + | * '''<tt>33</tt>''' – выдать текущий год в виде ГГ. |
− | * '''<tt>34</tt>''' | + | * '''<tt>34</tt>''' – выдать текущий месяц в виде М (без лидирующего нуля). |
− | * '''<tt>35</tt>''' | + | * '''<tt>35</tt>''' – выдать текущий день в виде Д (без лидирующего нуля). |
− | * '''<tt>36MM</tt>''' | + | * '''<tt>36MM</tt>''' – выдать по заданному номеру месяца его название на русском языке в именительном падеже. |
− | * '''<tt>37MM</tt>''' | + | * '''<tt>37MM</tt>''' – выдать по заданному номеру месяца его название на русском языке в родительном падеже. |
− | * '''<tt>38MM</tt>''' | + | * '''<tt>38MM</tt>''' – выдать по заданному номеру месяца его название на английском языке. |
− | * '''<tt>39</tt>''' | + | * '''<tt>39</tt>''' – выдать текущее время. |
− | * '''<tt>3А</tt>''' | + | * '''<tt>3А</tt>''' – выдать номер текущего дня от начала года. |
− | * '''<tt>3BГГГГММДД/ддд</tt>''' | + | * '''<tt>3BГГГГММДД/ддд</tt>''' – прибавить/вычесть из заданной даты в виде ГГГГММДД заданное количество дней (ддд – м.б. с минусом) и вернуть полученную дату в виде ГГГГММДД. |
− | * '''<tt>3СГГГГММДД/ГГГГММДД</tt>''' | + | * '''<tt>3СГГГГММДД/ГГГГММДД</tt>''' – вычесть из одной даты в виде ГГГГММДД другую дату в виде ГГГГММДД и вернуть разницу в виде количества дней. |
'''Примеры:''' | '''Примеры:''' | ||
Строка 145: | Строка 161: | ||
где: | где: | ||
* NNN – номер переменной. | * NNN – номер переменной. | ||
− | * nnn – номер повторения. По умолчанию | + | * nnn – номер повторения. По умолчанию – номер текущего повторения в повторяющейся группе. |
Эквивалентная конструкция языка форматирования GNNN. | Эквивалентная конструкция языка форматирования GNNN. | ||
'''Примеры:''' | '''Примеры:''' | ||
− | &unifor( | + | &unifor('+7R100') |
эквивалентная конструкция языка форматирования: | эквивалентная конструкция языка форматирования: | ||
G100 | G100 | ||
Строка 164: | Строка 180: | ||
'''Примеры:''' | '''Примеры:''' | ||
− | &unifor( | + | &unifor('+7W100#',(v910/)) |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
Строка 233: | Строка 249: | ||
+1RNNN,nnn | +1RNNN,nnn | ||
где: | где: | ||
− | * NNN – номер первой или единственной переменной, возможна конструкция *+-<число>. * | + | * NNN – номер первой или единственной переменной, возможна конструкция *+-<число>. * – номер текущего повторения в повторяющейся группе. |
* nnn – кол-во переменных (по умолчанию 1). | * nnn – кол-во переменных (по умолчанию 1). | ||
'''Примеры:''' | '''Примеры:''' | ||
− | &unifor( | + | &unifor('+1R100,2') |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
Строка 247: | Строка 263: | ||
+1WNNN,MMM#SSSS | +1WNNN,MMM#SSSS | ||
где: | где: | ||
− | * NNN – номер первой или единственной переменной, возможна конструкция *+-<число>. * | + | * NNN – номер первой или единственной переменной, возможна конструкция *+-<число>. * – номер текущего повторения в повторяющейся группе. |
* MMM – номер переменной для сохранения кол-ва записанных переменных (по умолчанию не используется). | * MMM – номер переменной для сохранения кол-ва записанных переменных (по умолчанию не используется). | ||
* SSSS – список строк (результат расформатирования). Если задан MMM – каждая строка пишется в отдельную переменную, в противном случае все пишется в одну переменную. | * SSSS – список строк (результат расформатирования). Если задан MMM – каждая строка пишется в отдельную переменную, в противном случае все пишется в одну переменную. | ||
'''Примеры:''' | '''Примеры:''' | ||
− | &unifor( | + | &unifor('+1W100,0#',(v910/)) |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
Строка 265: | Строка 281: | ||
'''Примеры:''' | '''Примеры:''' | ||
− | &unifor( | + | &unifor('+1Kmhr.mnu|100,10') |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
Строка 373: | Строка 389: | ||
1NCXY?V<tag>^<delim>*<offset>.<length>#<occur> | 1NCXY?V<tag>^<delim>*<offset>.<length>#<occur> | ||
где: | где: | ||
− | * N | + | * N – номер повторения подэлемента; если указана * – номер подэлемента совпадает со счетчиком повторяющейся группы. |
− | * ХY | + | * ХY – разделители между подэлементами. |
− | * С | + | * С – принимает значения: R – разделители справа от каждого подэлемента, кроме последнего; L – разделители слева от каждого подэлемента; D – каждый подэлемент заключен слева разделителем Х и справа – Y. |
− | * ? | + | * ? – символ-разделитель. |
* Остальные параметры аналогичны параметрам для функции {{Описание функции UNIFOR (ссылка)|name=A|title=Выдать заданное повторение поля}}. | * Остальные параметры аналогичны параметрам для функции {{Описание функции UNIFOR (ссылка)|name=A|title=Выдать заданное повторение поля}}. | ||
Строка 388: | Строка 404: | ||
J<dbn>,<термин> | J<dbn>,<термин> | ||
− | <dbn> | + | <dbn> – имя БД; по умолчанию используется текущая. |
'''Примеры:''' | '''Примеры:''' | ||
Строка 401: | Строка 417: | ||
D<dbn>,<@mfn|/termin/>,<@имя_формата|формат|*> | D<dbn>,<@mfn|/termin/>,<@имя_формата|формат|*> | ||
Передаются три параметра, разделенные запятой: | Передаются три параметра, разделенные запятой: | ||
− | * Первый | + | * Первый – имя БД; |
− | * Второй | + | * Второй – или непосредственно MFN с предшествующим символом @ или термин, ссылающийся на документ (термин – заключается в ограничительные символы); |
− | * Третий | + | * Третий – или имя формата с предшествующим символом @ или непосредственно формат. |
Если задается *, данные выводятся по прямой ссылке (метка поля, номер повторения). | Если задается *, данные выводятся по прямой ссылке (метка поля, номер повторения). | ||
Строка 417: | Строка 433: | ||
7<имя_БД>,</termin/>,<@имя_формата|формат|*> | 7<имя_БД>,</termin/>,<@имя_формата|формат|*> | ||
где: | где: | ||
− | * имя_БД | + | * имя_БД – имя базы данных, из которой будут браться связанные документы; по умолчанию используется текущая БД. |
− | * /termin/ | + | * /termin/ – ключевой термин, на основе которого отбираются связанные документы; термин заключается в уникальные ограничители (например. /), в качестве которых используется символ, не входящий (гарантированно) в термин. |
− | * @имя_формата|формат|* | + | * @имя_формата|формат|* – имя формата или формат в явном виде, в соответствии с которым будут расформатироваться связанные документы. Если задается имя формата, то он берется из директории БД, заданной параметром <имя_БД>. Если задается *, данные выводятся по прямой ссылке (метка поля, номер повторения). |
'''Примеры:''' | '''Примеры:''' | ||
Строка 427: | Строка 443: | ||
|name=! | |name=! | ||
|title=Команда постредактуры: очистить результат расформатирования от двойных разделителей | |title=Команда постредактуры: очистить результат расформатирования от двойных разделителей | ||
− | |description=Команда постредактуры: очистить результат расформатирования от двойных разделителей (двойных точек или двойных конструкций <. | + | |description=Команда постредактуры: очистить результат расформатирования от двойных разделителей (двойных точек или двойных конструкций <. – >). Имеет смысл использовать один раз в любом месте формата |
}} | }} | ||
Строка 457: | Строка 473: | ||
'''Примеры:''' | '''Примеры:''' | ||
− | &unifor( | + | &unifor('+1Omhr.mnu|',(v910^m/)) |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
Строка 481: | Строка 497: | ||
+I/содержание_ссылки/название_ссылки | +I/содержание_ссылки/название_ссылки | ||
− | '''/содержание_ссылки/''' | + | '''/содержание_ссылки/''' – внутренние данные ссылки, ограниченные уникальным разделителем. Имеют структуру |
NNN,HHH,<параметры> | NNN,HHH,<параметры> | ||
где: | где: | ||
− | * NNN | + | * NNN – тип ссылки, возможные значения: |
− | ** 0 | + | ** 0 – ссылки на внешние объекты; |
− | ** 1 | + | ** 1 – ссылка на связанный документ (возможно в другой БД) – "от одного к одному"; |
− | ** 2 | + | ** 2 – ссылка на связанные документы (возможно в другой БД) – "от одного к многим"; |
− | * HHH | + | * HHH – экранная подсказка, может иметь вид: @iii – где <tt>iii</tt> – номер текста в файле IRBISMSG.TXT, \text\ – собственно текст подсказки в уникальных ограничителях. |
'''<параметры>''': | '''<параметры>''': | ||
− | * Для ссылок типа 0 представляет собой в общем виде URL внешнего объекта (в том числе | + | * Для ссылок типа 0 представляет собой в общем виде URL внешнего объекта (в том числе – полный путь на файл). |
* Для ссылок типа 1 и 2 <параметры> имеют следующую структуру: | * Для ссылок типа 1 и 2 <параметры> имеют следующую структуру: | ||
имя_БД,имя_формата,termin | имя_БД,имя_формата,termin | ||
где: | где: | ||
− | * имя_БД | + | * имя_БД – имя базы данных, из которой будут браться связанные документы; по умолчанию используется текущая БД. |
− | * имя_формата | + | * имя_формата – имя формата, в соответствии с которым будут расформатироваться связанные документы. (по умолчанию – используется оптимизированный формат). |
− | * termin | + | * termin – ключевой термин, на основе которого отбираются (ищутся) связанные документы. |
Строка 514: | Строка 530: | ||
'''Примеры:''' | '''Примеры:''' | ||
− | (…&unifor( | + | (…&unifor('+4T1'),'_' &unifor('+4N1'),': ', &unifor('+4F1'),'<br>'…) |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
Строка 525: | Строка 541: | ||
'''Примеры:''' | '''Примеры:''' | ||
− | …(…&unifor( | + | …(…&unifor('+5Tfield.mnu'),' – ',&unifor('+5Ffield.mnu'),'<br>'…) |
{{Описание функции UNIFOR | {{Описание функции UNIFOR | ||
|name=+6 | |name=+6 | ||
|title=Выдать статус записи | |title=Выдать статус записи | ||
− | |description=Выдать статус записи. Если запись логически удаленная, возвращается 0, в противном случае | + | |description=Выдать статус записи. Если запись логически удаленная, возвращается 0, в противном случае – 1 |
}} | }} | ||
Строка 536: | Строка 552: | ||
'''Примеры:''' | '''Примеры:''' | ||
− | … if &unifor( | + | … if &unifor('+6')='0' then 'запись логически удаленная' fi … |
===Функции для работы с базой данных электронного каталога=== | ===Функции для работы с базой данных электронного каталога=== | ||
Строка 553: | Строка 569: | ||
|name=C | |name=C | ||
|title=Контроль ISSN/ISBN | |title=Контроль ISSN/ISBN | ||
− | |description=Контроль ISSN/ISBN. Возвращаемое значение: 0 | + | |description=Контроль ISSN/ISBN. Возвращаемое значение: 0 – при положительном результате, 1 – при отрицательном |
}} | }} | ||
Строка 578: | Строка 594: | ||
U<strbase>,<stradd> | U<strbase>,<stradd> | ||
где: | где: | ||
− | * <strbase> | + | * <strbase> – исходная кумулированная строка. |
− | * <stradd> | + | * <stradd> – кумулируемые номера. |
'''Примеры:''' | '''Примеры:''' | ||
Строка 591: | Строка 607: | ||
V<strbase> | V<strbase> | ||
где: | где: | ||
− | <strbase> | + | <strbase> – исходная строка для декумуляции. |
'''Примеры:''' | '''Примеры:''' | ||
Строка 603: | Строка 619: | ||
W<strbadd>,<strbase> | W<strbadd>,<strbase> | ||
где: | где: | ||
− | * <strbase> | + | * <strbase> – исходная кумулированная строка. |
− | * <stradd> | + | * <stradd> – кумулируемый номер. |
'''Возвращаемые значения:''' | '''Возвращаемые значения:''' | ||
− | * 0 | + | * 0 – если <stradd> не присутствует в <strbase>. |
− | * 1 | + | * 1 – если <stradd> присутствует в <strbase>. |
'''Примеры:''' | '''Примеры:''' | ||
Строка 628: | Строка 644: | ||
|name=M | |name=M | ||
|title=Отсортировать повторения заданного поля | |title=Отсортировать повторения заданного поля | ||
− | |description=Отсортировать повторения заданного поля (имеется в виду строковая сортировка) | + | |description=Отсортировать повторения заданного поля (имеется в виду строковая сортировка) – функция ничего не возвращает. Можно применять только в глобальной корректировке |
}} | }} | ||
MX<tag>^<delims> | MX<tag>^<delims> | ||
где: | где: | ||
− | * X | + | * X – вид сортировки: I – по возрастанию; D – по убыванию. |
− | * <tag> | + | * <tag> – метка поля. |
− | * <delims> | + | * <delims> – разделители подполей, определяющих ключ сортировки. |
'''Примеры:''' | '''Примеры:''' | ||
Строка 649: | Строка 665: | ||
SN | SN | ||
где: | где: | ||
− | * N=0 | + | * N=0 – обнулить счетчик. |
− | * N=1..9 | + | * N=1..9 – увеличить значение счетчика на со-отв. значение. |
− | * N=A | + | * N=A – вернуть значение счетчика – арабскими цифрами. |
− | * N=X | + | * N=X – вернуть значение счетчика – римскими цифрами. |
'''Примеры:''' | '''Примеры:''' | ||
Строка 665: | Строка 681: | ||
RNN | RNN | ||
− | где NN | + | где NN – кол-во знаков в случайном числе (по умолчанию – 6). |
'''Примеры:''' | '''Примеры:''' | ||
Строка 678: | Строка 694: | ||
+9T<исходные_данные> | +9T<исходные_данные> | ||
T – определяет тип и принимает следующие значения: | T – определяет тип и принимает следующие значения: | ||
− | * 0 | + | * 0 – вернуть номер текущего повторения в повторяющейся группе (исходные данные не задаются); |
− | * 1 | + | * 1 – вернуть имя файла из заданного полного пути/имени; |
− | * 2 | + | * 2 – вернуть путь из заданного полного пути/имени; |
− | * 3 | + | * 3 – вернуть расширение из заданного полного пути/имени; |
* 4 – вернуть имя диска из заданного полного пути; | * 4 – вернуть имя диска из заданного полного пути; | ||
− | * 5 | + | * 5 – вернуть длину исходной строки; |
− | * 6 | + | * 6 – вернуть фрагмент строки: |
+96A*SSS.NNN#<строка> | +96A*SSS.NNN#<строка> | ||
где: | где: | ||
− | ** A | + | ** A – направление: 0 – с начала строки; 1 – с конца; |
** SSS – смещение; | ** SSS – смещение; | ||
− | ** NNN | + | ** NNN – кол-во символов; |
− | * 7 | + | * 7 – вернуть строку в верхнем регистре; |
− | * 8 | + | * 8 – заменить в заданной строке один символ на другой (регистр учитывается): |
+98ab<строка> | +98ab<строка> | ||
где: | где: | ||
− | ** a | + | ** a – заменяемый символ; |
** b – заменяющий символ; | ** b – заменяющий символ; | ||
− | * 9 | + | * 9 – групповая установка глобальных переменных (для ИРБИС-Навигатора). Исходная строка закодирована через URLEncode (&unifor('+3E....). После раскодировки рассматривается как список строк(TStringList.Text). Каждая строка этого списка имеет структуру: NNN#<значение_глобальной_переменной_NNN>; |
* C – вставить данные из заданного текстового файла: | * C – вставить данные из заданного текстового файла: | ||
+9С<path>,<dbname>,<filename> | +9С<path>,<dbname>,<filename> | ||
Строка 704: | Строка 720: | ||
* D – сохранить заданный внутренний двоичный объект в заданном файле: +9DNN#<полный путь>, где NN – номер внутреннего двоичного объекта; | * D – сохранить заданный внутренний двоичный объект в заданном файле: +9DNN#<полный путь>, где NN – номер внутреннего двоичного объекта; | ||
* F – вернуть ANSI-символ с заданным кодом; | * F – вернуть ANSI-символ с заданным кодом; | ||
− | * G | + | * G – преобразовать заданную строку в список слов. |
[[Категория:Язык форматирования системы ИРБИС]] | [[Категория:Язык форматирования системы ИРБИС]] | ||
[[Категория:Анонсированные статьи]] | [[Категория:Анонсированные статьи]] |
Версия 18:28, 8 апреля 2010
UNIFOR – программная функция (также говорят формат-программа или форматный выход), предназначенная для вызова из форматов. UNIFOR реализует выполнение таких операций по форматированию, которые не могут быть выполнены с помощью собственно языка форматирования.
Содержание
- 1 Использование UNIFOR
- 2 Перечень функций формат-программы UNIFOR с примерами их применения
- 2.1 Функции для обработки строк
- 2.1.1 Удалить двойные кавычки из заданной строки – &uf('9…
- 2.1.2 Вернуть заданное количество слов с начала строки – &uf('E…
- 2.1.3 Вернуть часть строки, начиная со следующего слова после указанного и до конца строки – &uf('F…
- 2.1.4 Вернуть часть строки до или начиная с заданного символа – &uf('G…
- 2.1.5 Транслитерация кириллических символов с помощью латиницы – &uf('T…
- 2.1.6 Удаление из заданной строки фрагментов, выделенных угловыми скобками <> – &uf('X…
- 2.1.7 Вернуть заданную строку в нижнем регистре – &uf('Q…
- 2.1.8 Кодирование данных для представления в URL – &uf('+3E…
- 2.1.9 Декодирование данных из URL – &uf('+3D…
- 2.2 Функции для работы с датой и временем
- 2.3 Функции для работы с глобальными переменными
- 2.3.1 Очистить (опустошить) все глобальные переменные – &uf('+7…
- 2.3.2 Чтение глобальной переменной – &uf('+7R…
- 2.3.3 Запись глобальной переменной – &uf('+7W…
- 2.3.4 Добавление повторений глобальной переменной – &uf('+7U…
- 2.3.5 Логическое перемножение повторений двух переменных – &uf('+7M…
- 2.3.6 Логическое вычитание повторений двух переменных – &uf('+7S…
- 2.3.7 Логическое сложение повторений двух переменных – &uf('+7A…
- 2.3.8 Исключение неоригинальных повторений переменной – &uf('+7G…
- 2.3.9 Сортировка повторений переменной – &uf('+7T…
- 2.3.10 Очистить (опустошить) все глобальные переменные – &uf('+1…
- 2.3.11 Чтение глобальных переменных – &uf('+1R…
- 2.3.12 Запись в глобальные переменные – &uf('+1W…
- 2.3.13 Групповая мультираскодировка переменных – &uf('+1K…
- 2.3.14 Перемножение двух списков (групп переменных) – &uf('+1M…
- 2.3.15 Вычитание списков (групп переменных) – &uf('+1S…
- 2.3.16 Сложение списков (групп переменных) – &uf('+1A…
- 2.3.17 Исключение неоригинальных значений из группы переменных – &uf('+1G…
- 2.3.18 Сортировка группы переменных – &uf('+1T…
- 2.4 Функции для работы с базой данных
- 2.4.1 Выдать содержимое документа полностью – &uf('0…
- 2.4.2 Выдать заданное повторение поля – &uf('A…
- 2.4.3 Выдать заданное оригинальное повторение поля – &uf('P…
- 2.4.4 Раскодировка через справочник (меню) – &uf('K…
- 2.4.5 Вернуть параметр из INI-файла – &uf('I…
- 2.4.6 Вернуть заданный подэлемент – &uf('1…
- 2.4.7 Вернуть кол-во ссылок для заданного термина – &uf('J…
- 2.4.8 Форматирование документа из другой БД – &uf('D…
- 2.4.9 Расформатирование группы связанных документов из другой БД – &uf('7…
- 2.4.10 Команда постредактуры: очистить результат расформатирования от двойных разделителей – &uf('!…
- 2.4.11 Команда постредактуры: очистить результат расформатирования от RTF-конструкций – &uf('+F…
- 2.4.12 Групповая мультираскодировка списка – &uf('+1O…
- 2.4.13 Исключение неоригинальных значений из списка – &uf('+1I…
- 2.4.14 Сортировка списка – &uf('+1V…
- 2.4.15 Формирования ссылки (гиперссылки) – &uf('+I…
- 2.4.16 Выдача метки, порядкового номера и значения поля в соответствии с индексом (номером повторения) повторяющейся группы – &uf('+4…
- 2.4.17 Выдача элемента списка/справочника в соответствии с индексом (номером повторения) повторяющейся группы – &uf('+5…
- 2.4.18 Выдать статус записи – &uf('+6…
- 2.5 Функции для работы с базой данных электронного каталога
- 2.6 Функции, используемые только в глобальной корректировке
- 2.7 Функции, не вошедшие в другие категории
- 2.1 Функции для обработки строк
Использование UNIFOR
Обращение к программной функции UNIFOR в формате производится в полной или сокращённой форме:
&unifor(формат) &uf(формат)
где:
- & – идентификатор вызова формат-программы;
- unifor – имя формат-программы (соответственно uf – сокращённое имя формат-программы);
- формат – аргумент.
Рекомендуется использовать сокращённую форму вызова программной функции UNIFOR. Сокращённая форма по действию ничем не отличается от полной формы, зато позволяет сократить размер формата и повысить его читаемость.
Вид реализуемой функции определяется первыми символами строки, которая формируется в результате выполнения формата, передаваемого в качестве аргумента формат-программы.
Перечень функций формат-программы UNIFOR с примерами их применения
Функции для обработки строк
Удалить двойные кавычки из заданной строки – &uf('9…
Вид функции: 9.
Назначение: Удалить двойные кавычки из заданной строки.
Формат (передаваемая строка):
9<исх.строка>
Примеры:
&unifor("9"v200^a)
Вернуть заданное количество слов с начала строки – &uf('E…
Вид функции: E.
Назначение: Вернуть заданное количество слов с начала строки.
Формат (передаваемая строка):
EN<строка>
где N – количество слов (одна цифра).
Примеры:
&unifor("E3"v200^a)
Вернуть часть строки, начиная со следующего слова после указанного и до конца строки – &uf('F…
Вид функции: F.
Назначение: Вернуть часть строки, начиная со следующего слова после указанного и до конца строки.
Формат (передаваемая строка):
FN<строка>
где N – количество слов (одна цифра).
Примеры:
&unifor("F3"v200^a)
Вернуть часть строки до или начиная с заданного символа – &uf('G…
Вид функции: G.
Назначение: Вернуть часть строки до или начиная с заданного символа.
Формат (передаваемая строка):
GNA<строка>
где:
- N=0 если ДО заданного символа (не включая его); N=1 если начиная С заданного символа (включая его).
- А – заданный символ (# – обозначает цифру; $ – обозначает букву).
Примеры:
&unifor("G0#"v700) &unifor("G1-"v700^a)
Транслитерация кириллических символов с помощью латиницы – &uf('T…
Вид функции: T.
Назначение: Транслитерация кириллических символов с помощью латиницы.
Формат (передаваемая строка):
TN<строка>
где N – вид таблицы транслитерации (0 или 1).
Примеры:
&unifor("T0"V200)
Удаление из заданной строки фрагментов, выделенных угловыми скобками <> – &uf('X…
Вид функции: X.
Назначение: Удаление из заданной строки фрагментов, выделенных угловыми скобками <>.
Формат (передаваемая строка):
X<строка>
Примеры:
&unifor("X"v200)
Вернуть заданную строку в нижнем регистре – &uf('Q…
Вид функции: Q.
Назначение: Вернуть заданную строку в нижнем регистре.
Формат (передаваемая строка):
Q<строка>
Примеры:
&unifor("Q"v200)
Кодирование данных для представления в URL – &uf('+3E…
Вид функции: +3E.
Назначение: Кодирование данных для представления в URL.
Формат (передаваемая строка):
+3E<данные>
Примеры:
&unifor('+3E',v1007)
Декодирование данных из URL – &uf('+3D…
Вид функции: +3D.
Назначение: Декодирование данных из URL.
Формат (передаваемая строка):
+3D<данные>
Функции для работы с датой и временем
Выдача данных, связанных с датой и временем – &uf('3…
Вид функции: 3.
Назначение: Выдача данных, связанных с датой и временем.
Формат (передаваемая строка):
Имеются следующие подфункции:
- 3 – выдать текущую дату в виде ГГГГММДД.
- 30 – выдать текущий год в виде ГГГГ.
- 31 – выдать текущий месяц в виде ММ (с лидирующим нулем).
- 32 – выдать текущий день в виде ДД (с лидирующим нулем).
- 33 – выдать текущий год в виде ГГ.
- 34 – выдать текущий месяц в виде М (без лидирующего нуля).
- 35 – выдать текущий день в виде Д (без лидирующего нуля).
- 36MM – выдать по заданному номеру месяца его название на русском языке в именительном падеже.
- 37MM – выдать по заданному номеру месяца его название на русском языке в родительном падеже.
- 38MM – выдать по заданному номеру месяца его название на английском языке.
- 39 – выдать текущее время.
- 3А – выдать номер текущего дня от начала года.
- 3BГГГГММДД/ддд – прибавить/вычесть из заданной даты в виде ГГГГММДД заданное количество дней (ддд – м.б. с минусом) и вернуть полученную дату в виде ГГГГММДД.
- 3СГГГГММДД/ГГГГММДД – вычесть из одной даты в виде ГГГГММДД другую дату в виде ГГГГММДД и вернуть разницу в виде количества дней.
Примеры:
&unifor('36',&unifor('34'))
Функции для работы с глобальными переменными
Очистить (опустошить) все глобальные переменные – &uf('+7…
Вид функции: +7.
Назначение: Очистить (опустошить) все глобальные переменные.
Формат (передаваемая строка):
+7
Примеры:
&unifor('+7')
Чтение глобальной переменной – &uf('+7R…
Вид функции: +7R.
Назначение: Чтение глобальной переменной.
Формат (передаваемая строка):
+7RNNN,nnn
где:
- NNN – номер переменной.
- nnn – номер повторения. По умолчанию – номер текущего повторения в повторяющейся группе.
Эквивалентная конструкция языка форматирования GNNN.
Примеры:
&unifor('+7R100')
эквивалентная конструкция языка форматирования:
G100
Запись глобальной переменной – &uf('+7W…
Вид функции: +7W.
Назначение: Запись глобальной переменной.
Формат (передаваемая строка):
+7WNNN#SSSS
где:
- NNN – номер переменной;
- SSSS – список строк (результат расформатирования); каждая строка становится отдельным повторением.
Примеры:
&unifor('+7W100#',(v910/))
Добавление повторений глобальной переменной – &uf('+7U…
Вид функции: +7U.
Назначение: Добавление повторений глобальной переменной.
Формат (передаваемая строка):
+7UNNN#SSSS
где:
- NNN – номер переменной;
- SSSS – список строк (результат расформатирования); каждая строка становится отдельным повторением.
Логическое перемножение повторений двух переменных – &uf('+7M…
Вид функции: +7M.
Назначение: Логическое перемножение повторений двух переменных.
Формат (передаваемая строка):
+7MNNN#MMM
Результат перемножения записывается в первую переменную.
Логическое вычитание повторений двух переменных – &uf('+7S…
Вид функции: +7S.
Назначение: Логическое вычитание повторений двух переменных.
Формат (передаваемая строка):
+7SNNN#MMM
Результат вычитания записывается в первую переменную.
Логическое сложение повторений двух переменных – &uf('+7A…
Вид функции: +7A.
Назначение: Логическое сложение повторений двух переменных.
Формат (передаваемая строка):
+7ANNN#MMM
Результат сложения записывается в первую переменную.
Исключение неоригинальных повторений переменной – &uf('+7G…
Вид функции: +7G.
Назначение: Исключение неоригинальных повторений переменной.
Формат (передаваемая строка):
+7GNNN
Результат исключения записывается в ту же переменную.
Сортировка повторений переменной – &uf('+7T…
Вид функции: +7T.
Назначение: Сортировка повторений переменной.
Формат (передаваемая строка):
+7TNNN
Результат сортировки записывается в ту же переменную.
Очистить (опустошить) все глобальные переменные – &uf('+1…
Вид функции: +1.
Назначение: Очистить (опустошить) все глобальные переменные.
Формат (передаваемая строка):
+1
Примеры:
&unifor('+1')
Чтение глобальных переменных – &uf('+1R…
Вид функции: +1R.
Назначение: Чтение глобальных переменных.
Формат (передаваемая строка):
+1RNNN,nnn
где:
- NNN – номер первой или единственной переменной, возможна конструкция *+-<число>. * – номер текущего повторения в повторяющейся группе.
- nnn – кол-во переменных (по умолчанию 1).
Примеры:
&unifor('+1R100,2')
Запись в глобальные переменные – &uf('+1W…
Вид функции: +1W.
Назначение: Запись в глобальные переменные.
Формат (передаваемая строка):
+1WNNN,MMM#SSSS
где:
- NNN – номер первой или единственной переменной, возможна конструкция *+-<число>. * – номер текущего повторения в повторяющейся группе.
- MMM – номер переменной для сохранения кол-ва записанных переменных (по умолчанию не используется).
- SSSS – список строк (результат расформатирования). Если задан MMM – каждая строка пишется в отдельную переменную, в противном случае все пишется в одну переменную.
Примеры:
&unifor('+1W100,0#',(v910/))
Групповая мультираскодировка переменных – &uf('+1K…
Вид функции: +1K.
Назначение: Групповая мультираскодировка переменных.
Формат (передаваемая строка):
+1K<MNU>|NNN,nnn
где:
- NNN – номер первой или единственной переменной.
- nnn – кол-во переменных (по умолчанию 1).
Примеры:
&unifor('+1Kmhr.mnu|100,10')
Перемножение двух списков (групп переменных) – &uf('+1M…
Вид функции: +1M.
Назначение: Перемножение двух списков (групп переменных).
Формат (передаваемая строка):
+1MNNN,nnn#MMM,mmm
где параметры аналогичны описанным для функции Групповая мультираскодировка переменных – &uf('+1K…
Вычитание списков (групп переменных) – &uf('+1S…
Вид функции: +1S.
Назначение: Вычитание списков (групп переменных).
Формат (передаваемая строка):
+1SNNN,nnn#MMM,mmm
где параметры аналогичны описанным для функции Групповая мультираскодировка переменных – &uf('+1K…
Сложение списков (групп переменных) – &uf('+1A…
Вид функции: +1A.
Назначение: Сложение списков (групп переменных).
Формат (передаваемая строка):
+1ANNN,nnn#MMM,mmm
где параметры аналогичны описанным для функции Групповая мультираскодировка переменных – &uf('+1K…
Исключение неоригинальных значений из группы переменных – &uf('+1G…
Вид функции: +1G.
Назначение: Исключение неоригинальных значений из группы переменных.
Формат (передаваемая строка):
+1GNNN,nnn
где параметры аналогичны описанным для функции Групповая мультираскодировка переменных – &uf('+1K…
Сортировка группы переменных – &uf('+1T…
Вид функции: +1T.
Назначение: Сортировка группы переменных.
Формат (передаваемая строка):
+1TNNN,nnn
где параметры аналогичны описанным для функции Групповая мультираскодировка переменных – &uf('+1K…
Функции для работы с базой данных
Выдать содержимое документа полностью – &uf('0…
Вид функции: 0.
Назначение: Выдать содержимое документа полностью (формат ALLl).
Формат (передаваемая строка):
0
Примеры:
&unifor('0')
Выдать заданное повторение поля – &uf('A…
Вид функции: A.
Назначение: Выдать заданное повторение поля.
Формат (передаваемая строка):
AV<tag>^<delim>*<offset>.<length>#<occur>
где:
- <tag> – метка поля;
- <delim> – разделитель подполя;
- <offset> – смещение;
- <length> – длина;
- <occur> – номер повторения.
Примеры:
&unifor('Av200#2') &unifor('Av910^a#5') &unifor('Av10^b*2.10#2')
Выдать заданное оригинальное повторение поля – &uf('P…
Вид функции: P.
Назначение: Выдать заданное оригинальное повторение поля.
Формат (передаваемая строка): см. формат для функции Выдать заданное повторение поля – &uf('A….
Примеры: см. примеры для функции Выдать заданное повторение поля – &uf('A….
Раскодировка через справочник (меню) – &uf('K…
Вид функции: K.
Назначение: Раскодировка через справочник (меню).
Формат (передаваемая строка):
K<имя_меню>\<исх_значение>
Примеры:
&unifor("Kjz.mnu\"v101)
Вернуть параметр из INI-файла – &uf('I…
Вид функции: I.
Назначение: Вернуть параметр из INI-файла.
Формат (передаваемая строка):
I<SECTION>,<PAR_NAME>,<DE-FAULT_VALUE>
Примеры:
&unifor('IPRIVATE,NAME,NONAME')
Вернуть заданный подэлемент – &uf('1…
Вид функции: 1.
Назначение: Вернуть заданный подэлемент.
Формат (передаваемая строка):
1NCXY?V<tag>^<delim>*<offset>.<length>#<occur>
где:
- N – номер повторения подэлемента; если указана * – номер подэлемента совпадает со счетчиком повторяющейся группы.
- ХY – разделители между подэлементами.
- С – принимает значения: R – разделители справа от каждого подэлемента, кроме последнего; L – разделители слева от каждого подэлемента; D – каждый подэлемент заключен слева разделителем Х и справа – Y.
- ? – символ-разделитель.
- Остальные параметры аналогичны параметрам для функции Выдать заданное повторение поля – &uf('A….
Примеры:
(/&unifor('1*R; ?v910^h#1'))
Вернуть кол-во ссылок для заданного термина – &uf('J…
Вид функции: J.
Назначение: Вернуть кол-во ссылок для заданного термина.
Формат (передаваемая строка):
J<dbn>,<термин>
<dbn> – имя БД; по умолчанию используется текущая.
Примеры:
&unifor('JBOOK,',"A="v200^a)
Форматирование документа из другой БД – &uf('D…
Вид функции: D.
Назначение: Форматирование документа из другой БД (REF на другую БД – отношение «от одного к одному»).
Формат (передаваемая строка):
D<dbn>,<@mfn|/termin/>,<@имя_формата|формат|*>
Передаются три параметра, разделенные запятой:
- Первый – имя БД;
- Второй – или непосредственно MFN с предшествующим символом @ или термин, ссылающийся на документ (термин – заключается в ограничительные символы);
- Третий – или имя формата с предшествующим символом @ или непосредственно формат.
Если задается *, данные выводятся по прямой ссылке (метка поля, номер повторения).
Примеры:
&unifor('DBOOK,/K=AAA/,v200')
Расформатирование группы связанных документов из другой БД – &uf('7…
Вид функции: 7.
Назначение: Расформатирование группы связанных документов из другой БД (отношение «от одного к многим»).
Формат (передаваемая строка):
7<имя_БД>,</termin/>,<@имя_формата|формат|*>
где:
- имя_БД – имя базы данных, из которой будут браться связанные документы; по умолчанию используется текущая БД.
- /termin/ – ключевой термин, на основе которого отбираются связанные документы; термин заключается в уникальные ограничители (например. /), в качестве которых используется символ, не входящий (гарантированно) в термин.
- @имя_формата|формат|* – имя формата или формат в явном виде, в соответствии с которым будут расформатироваться связанные документы. Если задается имя формата, то он берется из директории БД, заданной параметром <имя_БД>. Если задается *, данные выводятся по прямой ссылке (метка поля, номер повторения).
Примеры:
&unifor('7TEST,',"/T="v200^a"/",',v903"\par "')
Команда постредактуры: очистить результат расформатирования от двойных разделителей – &uf('!…
Вид функции: !.
Назначение: Команда постредактуры: очистить результат расформатирования от двойных разделителей (двойных точек или двойных конструкций <. – >). Имеет смысл использовать один раз в любом месте формата.
Формат (передаваемая строка):
!
Примеры:
&unifor('!')
Команда постредактуры: очистить результат расформатирования от RTF-конструкций – &uf('+F…
Вид функции: +F.
Назначение: Команда постредактуры: очистить результат расформатирования от RTF-конструкций. Имеет смысл использовать один раз в любом месте формата.
Формат (передаваемая строка):
+F
Примеры:
&unifor('+F')
Групповая мультираскодировка списка – &uf('+1O…
Вид функции: +1O.
Назначение: Групповая мультираскодировка списка.
Формат (передаваемая строка):
+1O<MNU>|SSSS
где:
- <MNU> имя справочника (с расширением).
- SSSS – список строк (результат расформатирования.
Примеры:
&unifor('+1Omhr.mnu|',(v910^m/))
Исключение неоригинальных значений из списка – &uf('+1I…
Вид функции: +1I.
Назначение: Исключение неоригинальных значений из списка.
Формат (передаваемая строка):
+1ISSSS
где параметры аналогичны описанным для функции Групповая мультираскодировка списка – &uf('+1O…
Сортировка списка – &uf('+1V…
Вид функции: +1V.
Назначение: Сортировка списка.
Формат (передаваемая строка):
+1VSSSS
где параметры аналогичны описанным для функции Групповая мультираскодировка списка – &uf('+1O…
Формирования ссылки (гиперссылки) – &uf('+I…
Вид функции: +I.
Назначение: Формирования ссылки (гиперссылки).
Формат (передаваемая строка):
+I/содержание_ссылки/название_ссылки
/содержание_ссылки/ – внутренние данные ссылки, ограниченные уникальным разделителем. Имеют структуру
NNN,HHH,<параметры>
где:
- NNN – тип ссылки, возможные значения:
- 0 – ссылки на внешние объекты;
- 1 – ссылка на связанный документ (возможно в другой БД) – "от одного к одному";
- 2 – ссылка на связанные документы (возможно в другой БД) – "от одного к многим";
- HHH – экранная подсказка, может иметь вид: @iii – где iii – номер текста в файле IRBISMSG.TXT, \text\ – собственно текст подсказки в уникальных ограничителях.
<параметры>:
- Для ссылок типа 0 представляет собой в общем виде URL внешнего объекта (в том числе – полный путь на файл).
- Для ссылок типа 1 и 2 <параметры> имеют следующую структуру:
имя_БД,имя_формата,termin
где:
- имя_БД – имя базы данных, из которой будут браться связанные документы; по умолчанию используется текущая БД.
- имя_формата – имя формата, в соответствии с которым будут расформатироваться связанные документы. (по умолчанию – используется оптимизированный формат).
- termin – ключевой термин, на основе которого отбираются (ищутся) связанные документы.
Примеры:
&unifor('+I?0,,'v951^i'?',v951^t,|INTERNET|n951^t) &unifor(|+I?1,,,,I=|v421^w|?|,v421^a)
Выдача метки, порядкового номера и значения поля в соответствии с индексом (номером повторения) повторяющейся группы – &uf('+4…
Вид функции: +4.
Назначение: Выдача метки, порядкового номера и значения поля в соответствии с индексом (номером повторения) повторяющейся группы.
Формат (передаваемая строка):
+4XY
где:
- Х принимает три значения: T – выдать метку; F – выдать значение поле; N – выдать порядковый номер поля в записи (отличается от индекса повторения, если Y принимает значение 1);
- Y принимает значения: 0 – поля выдаются в порядке расположения в записи; 1 – поля выдаются в порядке возрастания меток (по умолчанию 0).
Примеры:
(…&unifor('+4T1'),'_' &unifor('+4N1'),': ', &unifor('+4F1'),'
'…)
Выдача элемента списка/справочника в соответствии с индексом (номером повторения) повторяющейся группы – &uf('+5…
Вид функции: +5.
Назначение: Выдача элемента списка/справочника в соответствии с индексом (номером повторения) повторяющейся группы.
Формат (передаваемая строка):
+5Х<имя_справочника/списка>
где Х принимает значения: Т – выдать значение; F – выдать пояснение (имеет смысл, если задается справочник, т.е. файл с расширением MNU).
Примеры:
…(…&unifor('+5Tfield.mnu'),' – ',&unifor('+5Ffield.mnu'),'
'…)
Выдать статус записи – &uf('+6…
Вид функции: +6.
Назначение: Выдать статус записи. Если запись логически удаленная, возвращается 0, в противном случае – 1.
Формат (передаваемая строка):
+6
Примеры:
… if &unifor('+6')='0' then 'запись логически удаленная' fi …
Функции для работы с базой данных электронного каталога
Выдать библиографическую свертку документа – &uf('B…
Вид функции: B.
Назначение: Выдать библиографическую свертку документа.
Формат (передаваемая строка):
B
Примеры:
&unifor('B')
Контроль ISSN/ISBN – &uf('C…
Вид функции: C.
Назначение: Контроль ISSN/ISBN. Возвращаемое значение: 0 – при положительном результате, 1 – при отрицательном.
Формат (передаваемая строка):
С<ISSN/ISBN>
Примеры:
&unifor("C"v10^a)
Вернуть окончание термина – &uf('L…
Вид функции: L.
Назначение: Вернуть окончание термина.
Формат (передаваемая строка):
L<начало_термина>
Примеры:
&unifor("L"v101)
Кумуляция номеров журналов – &uf('U…
Вид функции: U.
Назначение: Кумуляция номеров журналов.
Формат (передаваемая строка):
U<strbase>,<stradd>
где:
- <strbase> – исходная кумулированная строка.
- <stradd> – кумулируемые номера.
Примеры:
&unifor("U"v909^h",12")
Декумуляция номеров журналов – &uf('V…
Вид функции: V.
Назначение: Декумуляция номеров журналов.
Формат (передаваемая строка):
V<strbase>
где: <strbase> – исходная строка для декумуляции.
Примеры:
&unifor("V"v909^h")
Контроль кумуляции – &uf('W…
Вид функции: W.
Назначение: Контроль кумуляции.
Формат (передаваемая строка):
W<strbadd>,<strbase>
где:
- <strbase> – исходная кумулированная строка.
- <stradd> – кумулируемый номер.
Возвращаемые значения:
- 0 – если <stradd> не присутствует в <strbase>.
- 1 – если <stradd> присутствует в <strbase>.
Примеры:
&unifor("W12,"v909^h)
Функции, используемые только в глобальной корректировке
Размножение экземпляров – &uf('Z…
Вид функции: Z.
Назначение: Размножение экземпляров. Функция ничего не возвращает. Можно применять только в глобальной корректировке.
Формат (передаваемая строка):
Z
Примеры:
&unifor('Z')
Отсортировать повторения заданного поля – &uf('M…
Вид функции: M.
Назначение: Отсортировать повторения заданного поля (имеется в виду строковая сортировка) – функция ничего не возвращает. Можно применять только в глобальной корректировке.
Формат (передаваемая строка):
MX<tag>^<delims>
где:
- X – вид сортировки: I – по возрастанию; D – по убыванию.
- <tag> – метка поля.
- <delims> – разделители подполей, определяющих ключ сортировки.
Примеры:
&unifor('MI910^BD')
Функции, не вошедшие в другие категории
Универсальный счетчик – &uf('S…
Вид функции: S.
Назначение: Универсальный счетчик.
Формат (передаваемая строка):
SN
где:
- N=0 – обнулить счетчик.
- N=1..9 – увеличить значение счетчика на со-отв. значение.
- N=A – вернуть значение счетчика – арабскими цифрами.
- N=X – вернуть значение счетчика – римскими цифрами.
Примеры:
&unifor('S0') &unifor('S1') &unifor('SA')
Генерация случайного числа – &uf('R…
Вид функции: R.
Назначение: Генерация случайного числа.
Формат (передаваемая строка):
RNN
где NN – кол-во знаков в случайном числе (по умолчанию – 6).
Примеры:
&unifor('R10')
Группа технических форматных выходов – &uf('+9…
Вид функции: +9.
Назначение: Группа технических форматных выходов.
Формат (передаваемая строка):
+9T<исходные_данные>
T – определяет тип и принимает следующие значения:
- 0 – вернуть номер текущего повторения в повторяющейся группе (исходные данные не задаются);
- 1 – вернуть имя файла из заданного полного пути/имени;
- 2 – вернуть путь из заданного полного пути/имени;
- 3 – вернуть расширение из заданного полного пути/имени;
- 4 – вернуть имя диска из заданного полного пути;
- 5 – вернуть длину исходной строки;
- 6 – вернуть фрагмент строки:
+96A*SSS.NNN#<строка>
где:
- A – направление: 0 – с начала строки; 1 – с конца;
- SSS – смещение;
- NNN – кол-во символов;
- 7 – вернуть строку в верхнем регистре;
- 8 – заменить в заданной строке один символ на другой (регистр учитывается):
+98ab<строка>
где:
- a – заменяемый символ;
- b – заменяющий символ;
- 9 – групповая установка глобальных переменных (для ИРБИС-Навигатора). Исходная строка закодирована через URLEncode (&unifor('+3E....). После раскодировки рассматривается как список строк(TStringList.Text). Каждая строка этого списка имеет структуру: NNN#<значение_глобальной_переменной_NNN>;
- C – вставить данные из заданного текстового файла:
+9С<path>,<dbname>,<filename>
- <path> – определяет относительный путь к файлу в рамках ИР-БИС и принимает значения: 0 – основная директория системы (для ИРБИС32 – та, где находятся исполняемые модули; для ИРБИС64 – та, где находятся исполняемые модули сервера); 1 – общая директория баз данных (по умолчанию \DATAI); 10 – директо-рия конкретной БД;
- <dbname> – имя БД (имеет смысл только при path=10). По умолчанию – предполагается текущая БД;
- <filename> – имя файла;
- D – сохранить заданный внутренний двоичный объект в заданном файле: +9DNN#<полный путь>, где NN – номер внутреннего двоичного объекта;
- F – вернуть ANSI-символ с заданным кодом;
- G – преобразовать заданную строку в список слов.