Об’єкти Bytes¶
Ці функції викликають TypeError, коли очікується параметр bytes і викликаються з параметром, який не є байтом.
-
PyTypeObject
PyBytes_Type¶ Цей екземпляр
PyTypeObjectпредставляє тип Python bytes; це той самий об’єкт, що йbytesна рівні Python.
-
int
PyBytes_Check(PyObject *o)¶ Повертає true, якщо об’єкт o є об’єктом bytes або екземпляром підтипу типу bytes. Ця функція завжди успішна.
-
int
PyBytes_CheckExact(PyObject *o)¶ Повертає true, якщо об’єкт o є об’єктом bytes, але не екземпляром підтипу типу bytes. Ця функція завжди успішна.
-
PyObject*
PyBytes_FromString(const char *v)¶ - Return value: New reference.
Повертає новий об’єкт bytes із копією рядка v як значення в разі успіху та
NULLу разі помилки. Параметр v не має бутиNULL; перевірятися не буде.
-
PyObject*
PyBytes_FromStringAndSize(const char *v, Py_ssize_t len)¶ - Return value: New reference.
Повертає новий об’єкт bytes із копією рядка v як значення та довжиною len у разі успіху та
NULLу разі помилки. Якщо v має значенняNULL, вміст об’єкта bytes не ініціалізується.
-
PyObject*
PyBytes_FromFormat(const char *format, ...)¶ - Return value: New reference.
Візьміть рядок format у стилі C
printf()і змінну кількість аргументів, обчисліть розмір результуючого об’єкта Python bytes і поверніть об’єкт bytes із відформатованими значеннями. Змінні аргументи мають бути типу C і точно відповідати символам формату в рядку format. Дозволяються такі символи формату:Формат символів
Тип
коментар
%%немає
Літеральний символ %.
%cвнутр
Один байт, представлений як C int.
%dвнутр
Еквівалент
printf("%d"). 1%uunsigned int
Еквівалент
printf("%u"). 1%ldдовгота
Еквівалент
printf("%ld"). 1%luбеззнаковий довгий
Еквівалент
printf("%lu"). 1%zdЕквівалент
printf("%zd"). 1%zusize_t
Еквівалент
printf("%zu"). 1%iвнутр
Еквівалент
printf("%i"). 1%xвнутр
Еквівалент
printf("%x"). 1%sconst char*
Масив символів C із закінченням нулем.
%pconst void*
Шістнадцяткове представлення покажчика C. Здебільшого еквівалентний
printf("%p")за винятком того, що він гарантовано починається з літералу0xнезалежно від того, що даєprintfплатформи.Нерозпізнаний символ формату спричиняє копіювання всієї решти рядка формату в об’єкт результату як є, а будь-які додаткові аргументи відкидаються.
-
PyObject*
PyBytes_FromFormatV(const char *format, va_list vargs)¶ - Return value: New reference.
Ідентичний
PyBytes_FromFormat()за винятком того, що він приймає рівно два аргументи.
-
PyObject*
PyBytes_FromObject(PyObject *o)¶ - Return value: New reference.
Повертає представлення байтів об’єкта o, який реалізує протокол буфера.
-
Py_ssize_t
PyBytes_Size(PyObject *o)¶ Повертає довжину байтів у байтах об’єкт o.
-
Py_ssize_t
PyBytes_GET_SIZE(PyObject *o)¶ Macro form of
PyBytes_Size()but without error checking.
-
char*
PyBytes_AsString(PyObject *o)¶ Повернути вказівник на вміст o. Покажчик посилається на внутрішній буфер o, який складається з
len(o) + 1байтів. Останній байт у буфері завжди нульовий, незалежно від того, чи є інші нульові байти. Дані не можна змінювати жодним чином, якщо об’єкт не було щойно створено за допомогоюPyBytes_FromStringAndSize(NULL, size). Його не можна звільняти. Якщо o взагалі не є об’єктом bytes,PyBytes_AsString()повертаєNULLі викликаєTypeError.
-
char*
PyBytes_AS_STRING(PyObject *string)¶ Macro form of
PyBytes_AsString()but without error checking.
-
int
PyBytes_AsStringAndSize(PyObject *obj, char **buffer, Py_ssize_t *length)¶ Return the null-terminated contents of the object obj through the output variables buffer and length.
Якщо length дорівнює
NULL, об’єкт bytes може не містити вбудованих нульових байтів; якщо це так, функція повертає-1і викликаєValueError.Буфер відноситься до внутрішнього буфера obj, який містить додатковий нульовий байт у кінці (не враховується в довжині). Дані не можна змінювати жодним чином, якщо об’єкт не було щойно створено за допомогою
PyBytes_FromStringAndSize(NULL, size). Його не можна звільняти. Якщо obj взагалі не є об’єктом bytes,PyBytes_AsStringAndSize()повертає-1і викликаєTypeError.Змінено в версії 3.5: Раніше
TypeErrorвиникало, коли в об’єкті bytes зустрічалися вбудовані нульові байти.
-
void
PyBytes_Concat(PyObject **bytes, PyObject *newpart)¶ Створіть новий об’єкт bytes у *bytes, що містить вміст newpart, доданий до bytes; абонент буде володіти новим посиланням. Посилання на старе значення bytes буде викрадено. Якщо новий об’єкт неможливо створити, старе посилання на bytes все одно буде відкинуто, а значення *bytes буде встановлено на
NULL; буде встановлено відповідний виняток.
-
void
PyBytes_ConcatAndDel(PyObject **bytes, PyObject *newpart)¶ Create a new bytes object in *bytes containing the contents of newpart appended to bytes. This version decrements the reference count of newpart.
-
int
_PyBytes_Resize(PyObject **bytes, Py_ssize_t newsize)¶ A way to resize a bytes object even though it is «immutable». Only use this to build up a brand new bytes object; don’t use this if the bytes may already be known in other parts of the code. It is an error to call this function if the refcount on the input bytes object is not one. Pass the address of an existing bytes object as an lvalue (it may be written into), and the new size desired. On success, *bytes holds the resized bytes object and
0is returned; the address in *bytes may differ from its input value. If the reallocation fails, the original bytes object at *bytes is deallocated, *bytes is set toNULL,MemoryErroris set, and-1is returned.