n-uplets¶
-
PyTypeObject PyTuple_Type¶
- Fait partie de l' ABI stable.
Cette instance de
PyTypeObjectreprésente le type Pythontuple, c'est le même que l’objet Pythontuple.
-
int PyTuple_Check(PyObject *p)¶
Renvoie vrai si p est un
tupleou un instance d’un de ses sous-type. Cette fonction n’échoue jamais.
-
int PyTuple_CheckExact(PyObject *p)¶
Renvoie vrai uniquement si p est un
tuple, mais pas une instance d’un des sous-types. Cette fonction n’échoue jamais.
-
PyObject *PyTuple_New(Py_ssize_t len)¶
- Valeur de retour : nouvelle référence. Fait partie de l' ABI stable.
Return a new tuple object of size len, or
NULLwith an exception set on failure.
-
PyObject *PyTuple_FromArray(PyObject *const *array, Py_ssize_t size)¶
Create a tuple of size items and copy references from array to the new tuple.
array can be NULL if size is
0.On success, return a new reference. On error, set an exception and return
NULL.Ajouté dans la version 3.15.
-
PyObject *PyTuple_Pack(Py_ssize_t n, ...)¶
- Valeur de retour : nouvelle référence. Fait partie de l' ABI stable.
Return a new tuple object of size n, or
NULLwith an exception set on failure. The tuple values are initialized to the subsequent n C arguments pointing to Python objects.PyTuple_Pack(2, a, b)is equivalent toPy_BuildValue("(OO)", a, b).
-
Py_ssize_t PyTuple_Size(PyObject *p)¶
- Fait partie de l' ABI stable.
Take a pointer to a tuple object, and return the size of that tuple. On error, return
-1and with an exception set.
-
Py_ssize_t PyTuple_GET_SIZE(PyObject *p)¶
Like
PyTuple_Size(), but without error checking.
-
PyObject *PyTuple_GetItem(PyObject *p, Py_ssize_t pos)¶
- Valeur de retour : référence empruntée. Fait partie de l' ABI stable.
Renvoie l’objet à la position pos dans le n-uplet p. Si pos est négatif ou hors limites,
NULLest renvoyé et l’exceptionIndexErrorest levée.The returned reference is borrowed from the tuple p (that is: it is only valid as long as you hold a reference to p). To get a strong reference, use
Py_NewRef(PyTuple_GetItem(...))orPySequence_GetItem().
-
PyObject *PyTuple_GET_ITEM(PyObject *p, Py_ssize_t pos)¶
- Valeur de retour : référence empruntée.
Similaire à la fonction
PyTuple_GetItem(), mais ne contrôle pas les arguments.
-
PyObject *PyTuple_GetSlice(PyObject *p, Py_ssize_t low, Py_ssize_t high)¶
- Valeur de retour : nouvelle référence. Fait partie de l' ABI stable.
Return the slice of the tuple pointed to by p between low and high, or
NULLwith an exception set on failure.This is the equivalent of the Python expression
p[low:high]. Indexing from the end of the tuple is not supported.
-
int PyTuple_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o)¶
- Fait partie de l' ABI stable.
Insère une référence à l’objet o à la position pos du n-uplet pointé par p. Renvoie
0si l’opération réussit. Si pos est hors limite, l’exceptionIndexErrorest levée et la fonction renvoie-1.Note
Cette fonction « s’accapare » une référence à l’objet o et dé-référence l’objet présent dans le n-uplet à cette position.
-
void PyTuple_SET_ITEM(PyObject *p, Py_ssize_t pos, PyObject *o)¶
Semblable à la fonction
PyTuple_SetItem(), mais ne contrôle pas les erreurs et ne doit être utilisée que pour remplir un n-uplet nouvellement créé.Bounds checking is performed as an assertion if Python is built in debug mode or
with assertions.Note
Cette fonction « s’accapare » une référence à l’objet o et, contrairement à
PyTuple_SetItem(), ne dé-référence pas l’élément remplacé : la référence à l’objet présent dans le n-uplet à la position pos est perdue.Avertissement
This macro should only be used on tuples that are newly created. Using this macro on a tuple that is already in use (or in other words, has a refcount > 1) could lead to undefined behavior.
-
int _PyTuple_Resize(PyObject **p, Py_ssize_t newsize)¶
Permet de redimensionner un n-uplet. newsize est la nouvelle taille de ce n-uplet. Comme les n-uplets sont supposés être immuables cette fonction doit être utilisée uniquement s’il n’existe qu’une référence vers cet objet. N’utilisez pas cette fonction s’il est possible que le n-uplet soit connu d’une autre partie du code. Le n-uplet sera toujours agrandi ou réduit à partir de la fin. Cette fonction est plus performante que de détruire le
tuplepuis d’en créer un nouveau. Renvoie0si l’opération réussit. Le code ne devrait jamais supposer que la valeur de*psera la même après l’appel à cette fonction. Si l’objet référencé par*pdoit être remplacé, alors il est d’abord détruit. En cas d’erreur cette fonction renvoie-1, stockeNULLdans*pet lève soitMemoryErrorsoitSystemError.
Objets structure-séquence¶
Les objets structure-séquence sont l’équivalent C des objets namedtuple(), c’est-à-dire une liste d’objets dont les éléments peuvent être désignés par des attributs. Pour créer un objet structure-séquence vous devez d’abord définir son type.
-
PyTypeObject *PyStructSequence_NewType(PyStructSequence_Desc *desc)¶
- Valeur de retour : nouvelle référence. Fait partie de l' ABI stable.
Crée un nouveau type d’objet structure-séquence à partir des données dans desc, décrit ci-dessous. Le type ainsi créé peut être instancié en appelant
PyStructSequence_New().Return
NULLwith an exception set on failure.
-
void PyStructSequence_InitType(PyTypeObject *type, PyStructSequence_Desc *desc)¶
Initialise un type de structure-séquence à partir de desc, sur place.
-
int PyStructSequence_InitType2(PyTypeObject *type, PyStructSequence_Desc *desc)¶
Like
PyStructSequence_InitType(), but returns0on success and-1with an exception set on failure.Ajouté dans la version 3.4.
-
type PyStructSequence_Desc¶
- Fait partie de l' ABI stable (incluant tous les attributs).
Contient les méta-données d’un type structure-séquence à créer.
-
const char *name¶
Fully qualified name of the type; null-terminated UTF-8 encoded. The name must contain the module name.
-
const char *doc¶
Pointer to docstring for the type or
NULLto omit.
-
PyStructSequence_Field *fields¶
Pointer to
NULL-terminated array with field names of the new type.
-
int n_in_sequence¶
Number of fields visible to the Python side (if used as tuple).
-
const char *name¶
-
type PyStructSequence_Field¶
- Fait partie de l' ABI stable (incluant tous les attributs).
Describes a field of a struct sequence. As a struct sequence is modeled as a tuple, all fields are typed as PyObject*. The index in the
fieldsarray of thePyStructSequence_Descdetermines which field of the struct sequence is described.-
const char *name¶
Name for the field or
NULLto end the list of named fields, set toPyStructSequence_UnnamedFieldto leave unnamed.
-
const char *doc¶
Field docstring or
NULLto omit.
-
const char *name¶
-
const char *const PyStructSequence_UnnamedField¶
- Fait partie de l' ABI stable depuis la version 3.11.
Une valeur sentinelle pour indiquer qu’un champ n’est pas nommé.
Modifié dans la version 3.9: Le type était
char *.
-
PyObject *PyStructSequence_New(PyTypeObject *type)¶
- Valeur de retour : nouvelle référence. Fait partie de l' ABI stable.
Crée une instance de type, qui doit avoir été créé via
PyStructSequence_NewType().Return
NULLwith an exception set on failure.
-
PyObject *PyStructSequence_GetItem(PyObject *p, Py_ssize_t pos)¶
- Valeur de retour : référence empruntée. Fait partie de l' ABI stable.
Return the object at position pos in the struct sequence pointed to by p.
Bounds checking is performed as an assertion if Python is built in debug mode or
with assertions.
-
PyObject *PyStructSequence_GET_ITEM(PyObject *p, Py_ssize_t pos)¶
- Valeur de retour : référence empruntée.
Alias to
PyStructSequence_GetItem().Modifié dans la version 3.13: Now implemented as an alias to
PyStructSequence_GetItem().
-
void PyStructSequence_SetItem(PyObject *p, Py_ssize_t pos, PyObject *o)¶
- Fait partie de l' ABI stable.
Insère un l’objet o dans la structure-séquence p à la position pos. Pour les mêmes raisons que
PyTuple_SET_ITEM(), cette fonction ne doit être utilisée que pour des objets nouvellement créés.Bounds checking is performed as an assertion if Python is built in debug mode or
with assertions.Note
Cette fonction « s’accapare » une référence à o.
-
void PyStructSequence_SET_ITEM(PyObject *p, Py_ssize_t *pos, PyObject *o)¶
Alias to
PyStructSequence_SetItem().Modifié dans la version 3.13: Now implemented as an alias to
PyStructSequence_SetItem().