viktor.external.python
PythonAnalysis
- class viktor.external.python.PythonAnalysis(script=None, script_key='', files=None, output_filenames=None)
Bases:
ExternalProgram
New in 14.17.0PythonAnalysis can be used to evaluate a python script on third-party infrastructure. The script is expected to be blocking, i.e. if the script is invoked from command prompt, it should wait until the executable is finished. The default behaviour, is that the python script is defined within the app and send to the worker to be executed on third-party infrastructure. If desired (due to security considerations) the worker can be configured to only run local scripts. These scripts must be defined the in worker configuration file and can be selected through the script_key.
Usage:
script = vkt.File.from_path(Path(__file__).parent / "my_script.py") files = [ ('input1.txt', file1), ] python_analysis = PythonAnalysis(script=script, files=files, output_filenames=["output.txt"]) python_analysis.execute(timeout=60) output_file = python_analysis.get_output_file("output.txt")
Exceptions which can be raised during calculation:
viktor.errors.LicenseError
: no license availableviktor.errors.ExecutionError
: generic error. Error message provides more information
- Parameters:
script (
File
) – Script file that is transferred to the working directory on the server.script_key (
str
) – The key of the script that needs to be run. Only use this when the worker is configured to run local scripts. This key should be present in the configuration file of the worker.files (
List
[Tuple
[str
,Union
[BytesIO
,File
]]]) – Additional files that are transferred to the working directory on the server. Each file is a tuple containing the content and the filename which is used to save on the infrastructure.output_filenames (
List
[str
]) – A list of filenames (including extension) that are to be transferred back to the app. This filename is relative to the working directory.
Either one of ‘script’ or ‘script_key’ should be defined.
- Raises:
ValueError – when neither ‘script’ or ‘script_key’ is included OR when both are included.
- get_output_file(filename)
Method can be used to retrieve the results generated by running an external analysis. Call method
execute()
first andget_output_file()
afterwards.- Parameters:
filename (
str
) – The name of the file (including extension) that you want to get.- Return type:
Optional
[File
]