リストオブジェクト¶
-
PyTypeObject PyList_Type¶
- Part of the Stable ABI.
この
PyTypeObjectのインスタンスは Python のリスト型を表現します。これは Python レイヤにおけるlistと同じオブジェクトです。
-
PyObject *PyList_New(Py_ssize_t len)¶
- Return value: New reference. Part of the Stable ABI.
サイズが len 新たなリストオブジェクトを返します。 失敗すると
NULLを返します。注釈
len が0より大きいとき、返されるリストオブジェクトの要素には
NULLがセットされています。なので、PyList_SetItem()で本当にオブジェクトをセットするまでは、Pythonコードにこのオブジェクトを渡したり、PySequence_SetItem()のような抽象APIを利用してはいけません。
-
Py_ssize_t PyList_Size(PyObject *list)¶
- Part of the Stable ABI.
リストオブジェクト list の長さを返します; リストオブジェクトにおける
len(list)と同じです。
-
Py_ssize_t PyList_GET_SIZE(PyObject *list)¶
PyList_Size()に似ていますが、エラーチェックを行いません。
-
PyObject *PyList_GetItem(PyObject *list, Py_ssize_t index)¶
- Return value: Borrowed reference. Part of the Stable ABI.
Return the object at position index in the list pointed to by list. The position must be non-negative; indexing from the end of the list is not supported. If index is out of bounds (<0 or >=len(list)), return
NULLand set anIndexErrorexception.
-
PyObject *PyList_GET_ITEM(PyObject *list, Py_ssize_t i)¶
- Return value: Borrowed reference.
PyList_GetItem()に似ていますが、エラーチェックを行いません。
-
int PyList_SetItem(PyObject *list, Py_ssize_t index, PyObject *item)¶
- Part of the Stable ABI.
リストオブジェクト内の位置 index に、オブジェクト item を挿入します。 成功した場合には
0を返します。 index が範囲を越えている場合、-1を返してIndexErrorをセットします。注釈
この関数は item への参照を "盗み取り" ます。また、変更先のインデクスにすでに別の要素が入っている場合、その要素に対する参照を放棄します。
-
void PyList_SET_ITEM(PyObject *list, Py_ssize_t i, PyObject *o)¶
PyList_SetItem()をマクロによる実装で、エラーチェックを行いません。このマクロは、新たなリストのまだ要素を入れたことのない位置に要素を入れるときにのみ使います。注釈
このマクロは item への参照を "盗み取り" ます。また、
PyList_SetItem()と違って、要素の置き換えが生じても置き換えられるオブジェクトへの参照を放棄 しません ; その結果、 list 中の位置 i で参照されていたオブジェクトがメモリリークを引き起こします。
-
int PyList_Insert(PyObject *list, Py_ssize_t index, PyObject *item)¶
- Part of the Stable ABI.
要素 item をリスト list のインデックス index の前に挿入します。成功すると
0を返します。失敗すると-1を返し、例外をセットします。list.insert(index, item)に類似した機能です。
-
int PyList_Append(PyObject *list, PyObject *item)¶
- Part of the Stable ABI.
オブジェクト item を list の末尾に追加します。成功すると
0を返します; 失敗すると-1を返し、例外をセットします。list.append(item)に類似した機能です。
-
PyObject *PyList_GetSlice(PyObject *list, Py_ssize_t low, Py_ssize_t high)¶
- Return value: New reference. Part of the Stable ABI.
list 内の、low から high までの オブジェクトからなるリストを返します。 失敗すると
NULLを返し、例外をセットします。list[low:high]に類似した機能です。 ただし、リストの末尾からのインデックスはサポートされていません。
-
int PyList_SetSlice(PyObject *list, Py_ssize_t low, Py_ssize_t high, PyObject *itemlist)¶
- Part of the Stable ABI.
low から high までの list のスライスを、 itemlist の内容にします。
list[low:high] = itemlistと類似の機能です。 itemlist はNULLでもよく、空リストの代入 (指定スライスの削除) になります。 成功した場合には0を、失敗した場合には-1を返します。 ただし、リストの末尾からのインデックスはサポートされていません。
-
int PyList_Sort(PyObject *list)¶
- Part of the Stable ABI.
list の内容をインプレースでソートします。成功した場合には
0を、失敗した場合には-1を返します。list.sort()と同じです。
-
int PyList_Reverse(PyObject *list)¶
- Part of the Stable ABI.
list の要素をインプレースで反転します。成功した場合には
0を、失敗した場合には-1を返します。list.reverse()と同じです。
-
PyObject *PyList_AsTuple(PyObject *list)¶
- Return value: New reference. Part of the Stable ABI.
list の内容が入った新たなタプルオブジェクトを返します;
tuple(list)と同じです。