Об’єкти Bytes¶
Ці функції викликають TypeError
, коли очікується параметр bytes і викликаються з параметром, який не є байтом.
-
PyTypeObject PyBytes_Type¶
- Part of the Stable ABI.
Цей екземпляр
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. Part of the Stable ABI.
Повертає новий об’єкт bytes із копією рядка v як значення в разі успіху та
NULL
у разі помилки. Параметр v не має бутиNULL
; перевірятися не буде.
-
PyObject *PyBytes_FromStringAndSize(const char *v, Py_ssize_t len)¶
- Return value: New reference. Part of the Stable ABI.
Повертає новий об’єкт bytes із копією рядка v як значення та довжиною len у разі успіху та
NULL
у разі помилки. Якщо v має значенняNULL
, вміст об’єкта bytes не ініціалізується.Застаріло починаючи з версії 3.15:
PyBytes_FromStringAndSize(NULL, len)
is soft deprecated, use thePyBytesWriter
API instead.
-
PyObject *PyBytes_FromFormat(const char *format, ...)¶
- Return value: New reference. Part of the Stable ABI.
Візьміть рядок format у стилі C
printf()
і змінну кількість аргументів, обчисліть розмір результуючого об’єкта Python bytes і поверніть об’єкт bytes із відформатованими значеннями. Змінні аргументи мають бути типу C і точно відповідати символам формату в рядку format. Дозволяються такі символи формату:Формат символів
Тип
коментар
%%
немає
Літеральний символ %.
%c
внутр
Один байт, представлений як C int.
%d
внутр
Еквівалент
printf("%d")
. [1]%u
unsigned int
Еквівалент
printf("%u")
. [1]%ld
довгота
Еквівалент
printf("%ld")
. [1]%lu
беззнаковий довгий
Еквівалент
printf("%lu")
. [1]%zd
Еквівалент
printf("%zd")
. [1]%zu
size_t
Еквівалент
printf("%zu")
. [1]%i
внутр
Еквівалент
printf("%i")
. [1]%x
внутр
Еквівалент
printf("%x")
. [1]%s
const char*
Масив символів C із закінченням нулем.
%p
const void*
Шістнадцяткове представлення покажчика C. Здебільшого еквівалентний
printf("%p")
за винятком того, що він гарантовано починається з літералу0x
незалежно від того, що даєprintf
платформи.Нерозпізнаний символ формату спричиняє копіювання всієї решти рядка формату в об’єкт результату як є, а будь-які додаткові аргументи відкидаються.
-
PyObject *PyBytes_FromFormatV(const char *format, va_list vargs)¶
- Return value: New reference. Part of the Stable ABI.
Ідентичний
PyBytes_FromFormat()
за винятком того, що він приймає рівно два аргументи.
-
PyObject *PyBytes_FromObject(PyObject *o)¶
- Return value: New reference. Part of the Stable ABI.
Повертає представлення байтів об’єкта o, який реалізує протокол буфера.
-
Py_ssize_t PyBytes_Size(PyObject *o)¶
- Part of the Stable ABI.
Повертає довжину байтів у байтах об’єкт o.
-
Py_ssize_t PyBytes_GET_SIZE(PyObject *o)¶
Similar to
PyBytes_Size()
, but without error checking.
-
char *PyBytes_AsString(PyObject *o)¶
- Part of the Stable ABI.
Повернути вказівник на вміст o. Покажчик посилається на внутрішній буфер o, який складається з
len(o) + 1
байтів. Останній байт у буфері завжди нульовий, незалежно від того, чи є інші нульові байти. Дані не можна змінювати жодним чином, якщо об’єкт не було щойно створено за допомогоюPyBytes_FromStringAndSize(NULL, size)
. Його не можна звільняти. Якщо o взагалі не є об’єктом bytes,PyBytes_AsString()
повертаєNULL
і викликаєTypeError
.
-
char *PyBytes_AS_STRING(PyObject *string)¶
Similar to
PyBytes_AsString()
, but without error checking.
-
int PyBytes_AsStringAndSize(PyObject *obj, char **buffer, Py_ssize_t *length)¶
- Part of the Stable ABI.
Return the null-terminated contents of the object obj through the output variables buffer and length. Returns
0
on success.Якщо 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)¶
- Part of the Stable ABI.
Створіть новий об’єкт bytes у *bytes, що містить вміст newpart, доданий до bytes; абонент буде володіти новим посиланням. Посилання на старе значення bytes буде викрадено. Якщо новий об’єкт неможливо створити, старе посилання на bytes все одно буде відкинуто, а значення *bytes буде встановлено на
NULL
; буде встановлено відповідний виняток.
-
void PyBytes_ConcatAndDel(PyObject **bytes, PyObject *newpart)¶
- Part of the Stable ABI.
Create a new bytes object in *bytes containing the contents of newpart appended to bytes. This version releases the strong reference to newpart (i.e. decrements its reference count).
-
PyObject *PyBytes_Join(PyObject *sep, PyObject *iterable)¶
Similar to
sep.join(iterable)
in Python.sep must be Python
bytes
object. (Note thatPyUnicode_Join()
acceptsNULL
separator and treats it as a space, whereasPyBytes_Join()
doesn’t acceptNULL
separator.)iterable must be an iterable object yielding objects that implement the buffer protocol.
On success, return a new
bytes
object. On error, set an exception and returnNULL
.Added in version 3.14.
-
int _PyBytes_Resize(PyObject **bytes, Py_ssize_t newsize)¶
Resize a bytes object. newsize will be the new length of the bytes object. You can think of it as creating a new bytes object and destroying the old one, only more efficiently. 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
0
is 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
,MemoryError
is set, and-1
is returned.Застаріло починаючи з версії 3.15: The function is soft deprecated, use the
PyBytesWriter
API instead.
PyBytesWriter¶
The PyBytesWriter
API can be used to create a Python bytes
object.
Added in version 3.15.0a0 (unreleased).
-
type PyBytesWriter¶
A bytes writer instance.
The API is not thread safe: a writer should only be used by a single thread at the same time.
The instance must be destroyed by
PyBytesWriter_Finish()
on success, orPyBytesWriter_Discard()
on error.
Create, Finish, Discard¶
-
PyBytesWriter *PyBytesWriter_Create(Py_ssize_t size)¶
Create a
PyBytesWriter
to write size bytes.If size is greater than zero, allocate size bytes, and set the writer size to size. The caller is responsible to write size bytes using
PyBytesWriter_GetData()
.On error, set an exception and return NULL.
size must be positive or zero.
-
PyObject *PyBytesWriter_Finish(PyBytesWriter *writer)¶
Finish a
PyBytesWriter
created byPyBytesWriter_Create()
.On success, return a Python
bytes
object. On error, set an exception and returnNULL
.The writer instance is invalid after the call in any case. No API can be called on the writer after
PyBytesWriter_Finish()
.
-
PyObject *PyBytesWriter_FinishWithSize(PyBytesWriter *writer, Py_ssize_t size)¶
Similar to
PyBytesWriter_Finish()
, but resize the writer to size bytes before creating thebytes
object.
-
PyObject *PyBytesWriter_FinishWithPointer(PyBytesWriter *writer, void *buf)¶
Similar to
PyBytesWriter_Finish()
, but resize the writer using buf pointer before creating thebytes
object.Set an exception and return
NULL
if buf pointer is outside the internal buffer bounds.Function pseudo-code:
Py_ssize_t size = (char*)buf - (char*)PyBytesWriter_GetData(writer); return PyBytesWriter_FinishWithSize(writer, size);
-
void PyBytesWriter_Discard(PyBytesWriter *writer)¶
Discard a
PyBytesWriter
created byPyBytesWriter_Create()
.Do nothing if writer is
NULL
.The writer instance is invalid after the call. No API can be called on the writer after
PyBytesWriter_Discard()
.
High-level API¶
-
int PyBytesWriter_WriteBytes(PyBytesWriter *writer, const void *bytes, Py_ssize_t size)¶
Grow the writer internal buffer by size bytes, write size bytes of bytes at the writer end, and add size to the writer size.
If size is equal to
-1
, callstrlen(bytes)
to get the string length.On success, return
0
. On error, set an exception and return-1
.
-
int PyBytesWriter_Format(PyBytesWriter *writer, const char *format, ...)¶
Similar to
PyBytes_FromFormat()
, but write the output directly at the writer end. Grow the writer internal buffer on demand. Then add the written size to the writer size.On success, return
0
. On error, set an exception and return-1
.
Getters¶
-
Py_ssize_t PyBytesWriter_GetSize(PyBytesWriter *writer)¶
Get the writer size.
-
void *PyBytesWriter_GetData(PyBytesWriter *writer)¶
Get the writer data: start of the internal buffer.
The pointer is valid until
PyBytesWriter_Finish()
orPyBytesWriter_Discard()
is called on writer.
Low-level API¶
-
int PyBytesWriter_Resize(PyBytesWriter *writer, Py_ssize_t size)¶
Resize the writer to size bytes. It can be used to enlarge or to shrink the writer.
Newly allocated bytes are left uninitialized.
On success, return
0
. On error, set an exception and return-1
.size must be positive or zero.
-
int PyBytesWriter_Grow(PyBytesWriter *writer, Py_ssize_t grow)¶
Resize the writer by adding grow bytes to the current writer size.
Newly allocated bytes are left uninitialized.
On success, return
0
. On error, set an exception and return-1
.size can be negative to shrink the writer.
-
void *PyBytesWriter_GrowAndUpdatePointer(PyBytesWriter *writer, Py_ssize_t size, void *buf)¶
Similar to
PyBytesWriter_Grow()
, but update also the buf pointer.The buf pointer is moved if the internal buffer is moved in memory. The buf relative position within the internal buffer is left unchanged.
On error, set an exception and return
NULL
.buf must not be
NULL
.Function pseudo-code:
Py_ssize_t pos = (char*)buf - (char*)PyBytesWriter_GetData(writer); if (PyBytesWriter_Grow(writer, size) < 0) { return NULL; } return (char*)PyBytesWriter_GetData(writer) + pos;