InvokeModule(ModuleId: String, FunctionName: String, Params: Array): Variant;
ModuleId. Идентификатор Python-модуля в репозитории;
FunctionName. Наименование выполняемой функции;
Params. Массив значений параметров, передаваемых в функцию.
Метод InvokeModule выполняет функцию, хранящуюся в Python-модуле, и возвращает результат её работы.
Особенности использования параметров:
формат значения параметра ModuleId зависит от расположения Python-модуля в репозитории. Если Python-модуль содержится в объекте-контейнере, то значение параметра задаётся в формате: <идентификатор объекта-контейнера>.<идентификатор Python-модуля>;
значение параметра FunctionName является регистрозависимым.
Если выполняемая функция не содержит входных параметров, то Params можно не указывать. Значения параметров в Params могут быть переданы в виде отдельного массива или перечислены через запятую. Значения простых типов, таких как String, Char, Integer, Double, Decimal, Currency, Boolean (типы str, int, float, bool в Python), передаются в соответствии с синтаксисом Fore без каких-либо преобразований. Значение Null соответствует значению None в языке Python. Если функция Python принимает в качестве входного параметра объект какого-либо класса Python, список или кортеж, то необходимо создать соответствующий объект с помощью одного из следующих Fore-классов: PythonClassObject, PythonList, PythonTuple.
Если функция имеет параметры со значениями по умолчанию и при выполнении необходимо передать только часть параметров, то используйте именованные параметры. Именованные параметры реализует класс PythonParameter. Создайте параметры с необходимыми наименованиями, задайте им значения и передайте их в метод Invoke.
Для выполнения примера предполагается наличие в репозитории Python-модуля с идентификатором MOD_PYT. В модуле реализована следующая функция:
def summXY(x, y):
return x + y
Добавьте ссылку на системную сборку Python.
Sub UserProc;
Var
pUtils: IPythonUtils;
Result: Variant;
Begin
pUtils := New PythonUtils.Create;
Result := pUtils.InvokeModule("MOD_PYT", "summXY", 100, 500);
Debug.WriteLine(Result);
End Sub UserProc;
При выполнении примера будет выполнена функция на языке Python, осуществляющая сложение двух чисел, переданных в параметрах. Результат выполнения функции будет выведен в консоль среды разработки.
См. также: