"Python" (External Evaluation System)

Details

  • Python 3.4+ is supported.
  • In most cases, the Wolfram Language will automatically provision one Python environment, and no manual user configuration is required. For advanced configuration, follow the instructions from the Configure Python for ExternalEvaluate workflow.

ExternalEvaluate Usage

  • ExternalEvaluate["Python",code] executes Python code and returns the results as a Wolfram Language expression.
  • ExternalEvaluate[{"Python","Evaluator"evaluator},code] executes the code using a Python environment specified by evaluator.
  • The possible values for evaluator in ExternalEvaluate[{"Python","Evaluator"evaluator},] include:
  • "path"the location of a Python executable
    File["path"]the location of a Python executable
    Association[]a virtual environment specification
  • In ExternalEvaluate[{"Python","Evaluator"assoc},], possible elements of assoc include:
  • "Dependencies"{}packages automatically installed using pip
    "EnvironmentName"Automaticname of the virtual environment directory to be created
    "PythonRuntime"Automaticspecification of the Python runtime to be used, like "3.11" or File["/usr/bin/python3"]
    "BaseDirectory"Automaticthe directory of the created virtual environment
  • Possible settings for "type" in ExternalEvaluate["Python""type",code] include:
  • "Expression"attempt to convert to a Wolfram Language expression
    "String"give the raw string output by the external evaluator
    "ExternalObject"return the result as ExternalObject

Data Types

  • Not all Python built-in types are supported. The supported Python types are:
  • boolTrue|FalseBoolean values
    arrayNumericArrayarrays (from the NumPy library)
    bytearrayByteArraysequence of integers 0-255
    bytesByteArrayimmutable sequence of integers 0-255
    complexComplexcomplex number
    dateDateObjectspecific calendar date
    datetimeDateObjectspecific date with time granularity
    DecimalRealarbitrary-precision real number
    dictionaryAssociationassociation of keys and values
    floatRealreal-valued number
    FractionRationalfraction object from the fractions module
    frozensetListunordered immutable set of unique values
    ImageImageimage (from Python PIL library)
    intIntegerarbitrary-sized integer
    listListsequence of values
    longIntegerarbitrary-sized integer
    NoneNullnull value
    setListunordered set of unique values
    strStringsequence of character values
    tupleListordered sequence of values
    pyarrow.TableTabulartabular with rectangular data
  • Any unsupported Python type that is callable returns an ExternalFunction; any other unsupported Python type returns an ExternalObject.
  • The precision of a Real returned from a Decimal object is maintained when returned from ExternalEvaluate.
  • Python complex types are required to be real, so any Complex expression returned from ExternalEvaluate will have real-valued components.

Supported External Operations

  • ExternalOperation["Eval","code"] represents an external evaluation of "code".
  • ExternalOperation["Eval","code",assoc] represents an external evaluation of "code" with parameters given by assoc.
  • ExternalOperation["Call",func,arg1,arg2,] calls the function func with the given arguments arg1, arg2, .
  • ExternalOperation["GetAttribute",obj,"attr"] gets the attribute "attr" of obj.
  • ExternalOperation["SetAttribute",obj,"attr",val] sets the attribute "attr" of obj to the given value val.
  • ExternalOperation["GetItem",obj,"item"] gets the item "item" of obj.
  • ExternalOperation["SetItem",obj,"item",val] sets the item "item" of obj to the given value val.
  • ExternalOperation["Import","path"] imports the module "path".
  • ExternalOperation["Import","path","attr"] imports the module "path", then gets the attribute "attr" from the module.
  • ExternalOperation["Cast",obj,"type"] casts obj to the given "type".

Usage Notes

  • String templates (<**>) can be used to evaluate and insert Wolfram Language expressions into the Python code string.

Examples

open allclose all

Basic Examples  (3)

Evaluate in Python and return the result:

Create a list in Python and return the result:

Type > to get a Python code cell that uses ExternalEvaluate to evaluate:

import math [math.sqrt(i) for i in range(10)]

Create a list with exponentials and logarithms:

[[i,math.exp(i),math.log(i)] for i in range(1,10)]

Create a list with the days of the week:

import calendar [calendar.day_name[i] for i in range(7)]

Use the File wrapper to execute code contained in a file:

Deploy code using CloudDeploy and then run the code directly from a CloudObject:

Use a URL wrapper to directly run code hosted online:

An Association can be used to automatically provision a Python virtual environment:

The Python virtual environment was created under $UserBaseDirectory:

Scope  (51)

Evaluate a Boolean statement in Python and return the result:

Create a byte array in Python and return its equivalent in the Wolfram Language:

Another way to work with a byte array in Python:

Python list, tuple, set and frozenset are converted to List:

Python dict are converted to Association:

When using a Python higher than 3.7, dictionary keys are ordered, just like Association:

Create a Complex number in Python and return the result:

Fractions are automatically converted to Rational:

Decimals are converted to Real:

Fractions are automatically converted to Rational:

Decimals are converted to Real:

Datetime objects are automatically converted:

NumPy arrays are automatically converted to NumericArray:

Pandas DataFrames are automatically converted to Dataset:

PIL images are automatically converted to Image:

Generators are automatically converted to List:

Any Python object that is iterable will be automatically converted to a List unless an explicit conversion method is implemented:

Create a session to work with pyarrow module:

Create a Tabular object from Python data:

Use pyarrow to create Tabular from data of different shapes:

Pandas dataframes can be converted to Tabular objects by converting them to pyarrow first:

Close the session:

String templates can be used to insert Wolfram Language expressions into Python code. Set two variables:

The expression x^2+y^2 is evaluated in the Wolfram Language, and the result is converted and inserted into the Python code string:

Session Options  (12)

"ReturnType"  (3)

For the Python evaluation system, the default return type is "Expression":

Numbers, strings, lists and associations are automatically imported for the "Expression" return type:

The return type of "String" returns a string of the result by calling the Python function repr:

"Evaluator"  (5)

Evaluate Python code using a specified "Evaluator":

An Association can be used to automatically provision a Python virtual environment:

"Dependencies" can be a list of strings that specify Python packages, using pip conventions to specify versions:

The File wrapper can also be used in order to specify "Dependencies" for an evaluator:

Specify an "EnvironmentName" to customize the virtual environment folder name:

Specify a "BaseDirectory" to change the installation directory:

"PythonRuntime" can be used to download a specific version:

Use the File wrapper to use your own Python installation:

"SessionProlog"  (1)

Use "SessionProlog" to perform a side effect at the start of a session:

"SessionEpilog"  (1)

Use "SessionEpilog" to perform a side effect at the end of a session:

"Prolog"  (1)

Use "Prolog" to perform a side effect before every evaluation:

"Epilog"  (1)

Use "Epilog" to perform a side effect after every evaluation:

Command Options  (11)

"Command"  (4)

When only a string of Python code is provided, the command is directly executed:

The above is equivalent to writing the command using this form:

Use a File wrapper to run the code in a file:

The above is equivalent to writing the command using this form:

Use a URL wrapper to directly run code hosted online:

The above is equivalent to writing the command using this form:

Put code in a CloudObject:

Evaluate directly from the cloud:

The above is equivalent to writing the command using this form:

"ReturnType"  (1)

By default, the command is executed using the "ReturnType" specified during the session creation:

Specifying a "ReturnType" in the command overrides the "ReturnType" for the session:

"Arguments"  (2)

Use "Arguments" to call a Python function with arguments:

When a non-list argument is provided, a single argument is passed to the function:

If you need to pass a list as the first argument, you must wrap it with an extra list explicitly:

You can define a function inside "Command" and directly call it with "Arguments":

The same result can be achieved by using a Rule:

You can also pass arguments by creating an ExternalFunction:

"Constants"  (1)

Use "Constants" to permanently set global variables before the command runs:

"TemplateArguments"  (3)

When running a command, you can inline a TemplateExpression:

You can explicitly fill TemplateSlot using "TemplateArguments":

When a non-list argument is provided, a single template argument is passed to the template:

If you need to pass a list as the first argument, you must wrap it with an extra list explicitly:

You can name template slots and use an Association to pass named arguments to the template:

External Operations  (16)

"Eval"  (1)

Run an ExternalOperation that represents arbitrary code evaluation in Python:

Use the second argument to pass an evaluation context:

"Call"  (3)

Define an ExternalOperation that creates a function in Python:

Define a function call by running the ExternalOperation "Call":

Run the external operation representing the function call using ExternalEvaluate:

Any argument of the "Call" operation can be an ExternalOperation:

Arguments can also be passed directly in ExternalEvaluate by doing the following:

The result is equivalent of running the following Python code:

Create an ExternalFunction for a Python function:

Call the function by running the operation "Call":

The same result can be achieved by doing the following:

Create an ExternalObject for a Python function:

Call the function by running the operation "Call":

The same result can be achieved by doing the following:

Alternatively, you can use ExternalObject subvalues:

Close the session:

"GetAttribute"  (1)

Start a Python session to work with dates:

Return an ExternalObject for a datetime object:

Extract the year attribute by using "GetAttribute":

The same can be done using an ExternalObject subvalue:

For the Python evaluator, "GetAttribute" is the default operation, and ExternalOperation can be omitted:

The result is equivalent to running the following Python code:

Delete the session:

"SetAttribute"  (1)

Start a Python session to work with decimal numbers:

Get the context for the decimal module:

Set the precision to 6:

Check that the precision was set to 6:

The result is equivalent to running the following Python code:

Delete the session:

"GetItem"  (2)

Start a Python session:

Create a Python dictionary and return it as an ExternalObject:

Extract the "name" item by using "GetItem":

The result is equivalent to running the following Python code:

Delete the session:

Create an ExternalOperation that represents a dictionary:

Create a new ExternalOperation to get the item "name":

Run the operation using ExternalEvaluate:

"SetItem"  (1)

Start a Python session:

Create an ExternalObject with a dictionary:

Set the item "name" to "joe":

Check that the item was set to "joe":

Get the whole dictionary as an association, by using Expression:

Delete the session:

"Import"  (6)

Define an ExternalObject that imports the "datetime" module:

Return the module as an ExternalObject:

Define an ExternalObject that imports the date from the "datetime" module:

Call the operation with arguments using ExternalEvaluate:

Define an ExternalObject that imports the "datetime" module:

Use an ExternalFunction to call the method:

Delete the session:

Define an ExternalObject that imports the fractions module:

Initialize the fraction by using ExternalObject subvalues:

The same can be done with the following syntax:

Delete the session:

Define an "Import" operation that imports "ip_address":

Create an address instance using ExternalEvaluate:

Use String as the return type to show the Python string version of the instance:

Define an "Import" operation that imports "ip_address":

Create an address instance using another ExternalOperation:

Execute the operation in ExternalEvaluate:

"Cast"  (1)

Create an ExternalObject that represents the current date:

Use "Expression" to return the object as a Wolfram Language expression:

The Cast operation can also run in ExternalObject subvalues:

The symbol Expression is a shortcut for the same:

Return the object as a string:

The symbol String is a shortcut for the same:

Return the object as an ExternalObject:

The symbol ExternalObject is a shortcut for the same:

The same can be achieved by using "ReturnType" in ExternalEvaluate:

Delete the session:

Applications  (3)

Expose the Python range function in Wolfram Language:

Use the function:

Create a function that returns AST for a string of Python code using an AST module:

Use the function:

Use Pygments to create a function that does syntax highlighting of a block of code:

Use the function:

Properties & Relations  (1)

You can use to return expressions from Python:

Expressions automatically evaluate after they are transferred in a kernel.

Use Hold to control evaluation:

Close the session:

Possible Issues  (1)

Generators are automatically converted to List:

Returning an infinite generator will block your kernel forever: