Язык Python является универсальным языком, поддерживающим выполнение кода на других языках, таких как Java, C и C#. Для взаимодействия с Python в «Форсайт. Аналитическая платформа» был создан специальный набор внешних библиотек. Данные библиотеки позволяют работать с ядром «Форсайт. Аналитическая платформа». Библиотеки доступны в папке S\Interops\python\ после установки инсталлятора FP9PythonInterops.exe, где S - путь, по которому установлен продукт «Форсайт. Аналитическая платформа».
Примечание. Используемая версия Python должна совпадать с версией, которая использовалась при сборке внешних библиотек. В текущей реализации используется Python версии 3.7.8 при сборке библиотек для WIndows и версии 3.5 при сборке библиотек для Linux. При необходимости получения библиотек других версий обращайтесь в техническую поддержку по адресу support@fsight.ru или через сервисы технической поддержки, которые доступны после регистрации на сайте.
В коде пропишите строку импорта типов из внешней сборки в одном из следующих форматов:
from foresight.<Имя модуля> import * #Импорт всех классов/интерфейсов библиотеки.
from foresight.<Имя модуля> import <имя класса> #Импорт конкретного класса/интерфейс.
import foresight.<Имя модуля> as <переменная> #Импорт класса под определенным именем.
При создании внешних библиотек для использования в Python происходит специальное преобразование системных классов, интерфейсов, перечислений и других типов. При создании кода на Python с использованием ресурсов «Форсайт. Аналитическая платформа» необходимо учитывать следующие изменения:
Свойствам сопоставлены методы в следующих форматах: get_<имя свойства>([<параметры>]) и put_<имя свойства>(<значение>). Get возвращает значение свойства, а Put устанавливает указанное значение.
К именам классов добавлена буква C, например: классу MetabaseManagerFactory в Fore соответствует CMetabaseManagerFactory в Python.
Для создания объекта нужного класса используется конструкция <Имя класса>.Create() или <Имя класса>.Create<имя интерфейса>() без ключевого слова new.
Для приведения типов необходимо передавать имеющийся объект как параметр, например:
import foresight.metabase as modmetabase
...
creds = pack.CreateCredentials(amPassword)
pswdCreds = modmetabase.IPasswordCredentials(creds)
Ниже приведены примеры реализации различных процедур/функций на языке Fore и их аналоги на языке Python. Для простоты восприятия наименования переменных и комментарии в функциях оставлены одинаковыми.
Пример подключения к репозиторию в коде на Python:
from foresight.metabase import * #Импорт содержимого всей сборки Metabase
def ConnectMB():
# Менеджер репозиториев
mbFactory = CMetabaseManagerFactory.Create()
mbMan = mbFactory.Active
# Все описания репозиториев
mbDefs = mbMan.Definitions
mbDefs.ReadFromRegistry()
# Получение описания репозитория, к которому осуществляется подключение
mbDef = mbDefs.FindById('Repository')
# Модуля безопасности
pack = mbMan.Packs.FindById(mbDef.get_SecurityPackage()).Package
# Создание и настройка учётных данных для подключения
creds = pack.CreateCredentials(amPassword)
pswdCreds = IPasswordCredentials(creds)
pswdCreds.UserName = 'user'
pswdCreds.Password = 'password'
# Подключение к репозиторию и возврат контекста для работы с содержимым репозитория
mb = mbDef.OpenDefault(pswdCreds)
return mb
if __name__ == '__main__':
mb = ConnectMB()
print(mb.Name)
Получение описания объекта. В качестве первого параметра передаётся контекст репозитория, который возвращает функция ConnectMB:
from foresight.metabase import *
def GetMbObject(mb, id):
# Получение описания объекта путём получения значения свойства IMetabase.ItemById
mdesc = mb.get_ItemById(id)
return mdesc
Открытие регламентного отчёта, изменение значения в ячейке и сохранение изменений. В качестве значения первого параметра передаётся описание регламентного отчёта, которое можно получить, используя предыдущую функцию GetMbObject:
from foresight.metabase import *
from foresight.report import *
from foresight.tab import *
def EditPrxReport(mdesc, newValue):
# Открытие отчёта на редактирование и приведение результата к типу IPrxReport
report = IPrxReport(mdesc.Edit())
# Получение таблицы активного листа
ptable = IPrxTable(report.get_ActiveSheet())
sheet = ITabSheet(ptable.get_TabSheet())
# Изменение значения в ячейке
sheet.get_Cell(0, 0).put_Value(newValue)
# Сохранение изменений
report.get_MetabaseObject().Save()
# Проверка установленного значения для ячейки
print(sheet.get_Cell(0, 0).get_Value())
Открытие куба, формирование отметки, расчёт и возврат результирующей матрицы куба:
import ctypes
from foresight.cubes import *
from foresight.dimensions import *
from foresight.matrix import *
from foresight.metabase import *
def GetCubeMatrix(mdesc):
# Открытие куба
cube = ICubeInstance(mdesc.Open(None ))
# Получение экземпляра варианта отображения куба
destInst = ICubeInstanceDestination(cube.get_Destinations().get_DefaultDestination())
# Создание отметки
dimSS = IDimSelectionSet(destInst.CreateDimSelectionSet())
# Отметка всех элементов во всех измерениях
c = dimSS.get_Count();
for i in range(c):
dimS = dimSS.get_Item(i)
dimS.SelectAll()
# Расчёт результирующей матрицы куба
matr = IMatrix(destInst.Execute(dimSS, ctypes.c_uint(-1).value))
# Возврат полученной матрицы
return matr;
См. также: