From the pycall docs:
From Julia to Python
Assuming you have NumPy installed (true by default if you use Conda), then a Julia
a::Array
of NumPy-compatible elements is converted byPyObject(a)
into a NumPy wrapper for the same data , i.e. without copying the data. Julia arrays are stored in column-major order, and since NumPy supports column-major arrays this is not a problem.However, the default ordering of NumPy arrays created in Python is row-major, and some Python packages will throw an error if you try to pass them column-major NumPy arrays. To deal with this, you can use
PyReverseDims(a)
to pass a Julia array as a row-major NumPy array with the dimensions reversed . For example, ifa
is a 3x4x5 Julia array, thenPyReverseDims(a)
passes it as a 5x4x3 NumPy row-major array (without making a copy of the underlying data).A
Vector{UInt8}
object in Julia, by default, is converted to a Pythonbytearray
object. If you want abytes
object instead, you can use the functionpybytes(a)
.From Python to Julia
Multidimensional NumPy arrays (
ndarray
) are supported and can be converted to the native JuliaArray
type, which makes a copy of the data.Alternatively, the PyCall module also provides a new type
PyArray
(a subclass ofAbstractArray
) which implements a no-copy wrapper around a NumPy array (currently of numeric types or objects only). Just usePyArray
as the return type of apycall
returning anndarray
, or callPyArray(o::PyObject)
on anndarray
objecto
. (Technically, aPyArray
works for any Python object that uses the NumPy array interface to provide a data pointer and shape information.)Conversely, when passing arrays to Python, Julia
Array
types are converted toPyObject
types without making a copy via NumPy, e.g. when passed aspycall
arguments.
There is more information here .