MemoryView objects¶
Amemoryview
object exposes the C levelbuffer interface as a Python object which can then be passed around likeany other object.
- PyObject*PyMemoryView_FromObject(PyObject*obj)¶
- Return value: New reference. Part of theStable ABI.
Create a memoryview object from an object that provides the buffer interface.Ifobj supports writable buffer exports, the memoryview object will beread/write, otherwise it may be either read-only or read/write at thediscretion of the exporter.
- PyBUF_READ¶
Flag to request a readonly buffer.
- PyBUF_WRITE¶
Flag to request a writable buffer.
- PyObject*PyMemoryView_FromMemory(char*mem,Py_ssize_tsize,intflags)¶
- Return value: New reference. Part of theStable ABI since version 3.7.
Create a memoryview object usingmem as the underlying buffer.flags can be one of
PyBUF_READ
orPyBUF_WRITE
.Added in version 3.3.
- PyObject*PyMemoryView_FromBuffer(constPy_buffer*view)¶
- Return value: New reference. Part of theStable ABI since version 3.11.
Create a memoryview object wrapping the given buffer structureview.For simple byte buffers,
PyMemoryView_FromMemory()
is the preferredfunction.
- PyObject*PyMemoryView_GetContiguous(PyObject*obj,intbuffertype,charorder)¶
- Return value: New reference. Part of theStable ABI.
Create a memoryview object to acontiguous chunk of memory (in either‘C’ or ‘F’ortranorder) from an object that defines the bufferinterface. If memory is contiguous, the memoryview object points to theoriginal memory. Otherwise, a copy is made and the memoryview points to anew bytes object.
buffertype can be one of
PyBUF_READ
orPyBUF_WRITE
.
- intPyMemoryView_Check(PyObject*obj)¶
Return true if the objectobj is a memoryview object. It is notcurrently allowed to create subclasses of
memoryview
. Thisfunction always succeeds.
- Py_buffer*PyMemoryView_GET_BUFFER(PyObject*mview)¶
Return a pointer to the memoryview’s private copy of the exporter’s buffer.mviewmust be a memoryview instance; this macro doesn’t check its type,you must do it yourself or you will risk crashes.
- PyObject*PyMemoryView_GET_BASE(PyObject*mview)¶
Return either a pointer to the exporting object that the memoryview is basedon or
NULL
if the memoryview has been created by one of the functionsPyMemoryView_FromMemory()
orPyMemoryView_FromBuffer()
.mviewmust be a memoryview instance.