2008-01-19 18:08:21 -04:00
|
|
|
.. highlightlang:: c
|
|
|
|
|
|
|
|
.. _setobjects:
|
|
|
|
|
|
|
|
Set Objects
|
|
|
|
-----------
|
|
|
|
|
|
|
|
.. sectionauthor:: Raymond D. Hettinger <python@rcn.com>
|
|
|
|
|
|
|
|
|
|
|
|
.. index::
|
|
|
|
object: set
|
|
|
|
object: frozenset
|
|
|
|
|
|
|
|
.. versionadded:: 2.5
|
|
|
|
|
|
|
|
This section details the public API for :class:`set` and :class:`frozenset`
|
|
|
|
objects. Any functionality not listed below is best accessed using the either
|
|
|
|
the abstract object protocol (including :cfunc:`PyObject_CallMethod`,
|
|
|
|
:cfunc:`PyObject_RichCompareBool`, :cfunc:`PyObject_Hash`,
|
|
|
|
:cfunc:`PyObject_Repr`, :cfunc:`PyObject_IsTrue`, :cfunc:`PyObject_Print`, and
|
|
|
|
:cfunc:`PyObject_GetIter`) or the abstract number protocol (including
|
|
|
|
:cfunc:`PyNumber_And`, :cfunc:`PyNumber_Subtract`, :cfunc:`PyNumber_Or`,
|
|
|
|
:cfunc:`PyNumber_Xor`, :cfunc:`PyNumber_InPlaceAnd`,
|
|
|
|
:cfunc:`PyNumber_InPlaceSubtract`, :cfunc:`PyNumber_InPlaceOr`, and
|
|
|
|
:cfunc:`PyNumber_InPlaceXor`).
|
|
|
|
|
|
|
|
|
|
|
|
.. ctype:: PySetObject
|
|
|
|
|
|
|
|
This subtype of :ctype:`PyObject` is used to hold the internal data for both
|
|
|
|
:class:`set` and :class:`frozenset` objects. It is like a :ctype:`PyDictObject`
|
|
|
|
in that it is a fixed size for small sets (much like tuple storage) and will
|
|
|
|
point to a separate, variable sized block of memory for medium and large sized
|
|
|
|
sets (much like list storage). None of the fields of this structure should be
|
|
|
|
considered public and are subject to change. All access should be done through
|
|
|
|
the documented API rather than by manipulating the values in the structure.
|
|
|
|
|
|
|
|
|
|
|
|
.. cvar:: PyTypeObject PySet_Type
|
|
|
|
|
|
|
|
This is an instance of :ctype:`PyTypeObject` representing the Python
|
|
|
|
:class:`set` type.
|
|
|
|
|
|
|
|
|
|
|
|
.. cvar:: PyTypeObject PyFrozenSet_Type
|
|
|
|
|
|
|
|
This is an instance of :ctype:`PyTypeObject` representing the Python
|
|
|
|
:class:`frozenset` type.
|
|
|
|
|
|
|
|
The following type check macros work on pointers to any Python object. Likewise,
|
|
|
|
the constructor functions work with any iterable Python object.
|
|
|
|
|
|
|
|
|
2008-01-28 17:48:07 -04:00
|
|
|
.. cfunction:: int PySet_Check(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`set` object or an instance of a subtype.
|
|
|
|
|
|
|
|
.. versionadded:: 2.6
|
|
|
|
|
2008-02-03 18:51:43 -04:00
|
|
|
.. cfunction:: int PyFrozenSet_Check(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`frozenset` object or an instance of a
|
|
|
|
subtype.
|
|
|
|
|
|
|
|
.. versionadded:: 2.6
|
|
|
|
|
2008-01-19 18:08:21 -04:00
|
|
|
.. cfunction:: int PyAnySet_Check(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`set` object, a :class:`frozenset` object, or an
|
|
|
|
instance of a subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PyAnySet_CheckExact(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`set` object or a :class:`frozenset` object but
|
|
|
|
not an instance of a subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PyFrozenSet_CheckExact(PyObject *p)
|
|
|
|
|
|
|
|
Return true if *p* is a :class:`frozenset` object but not an instance of a
|
|
|
|
subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: PyObject* PySet_New(PyObject *iterable)
|
|
|
|
|
|
|
|
Return a new :class:`set` containing objects returned by the *iterable*. The
|
|
|
|
*iterable* may be *NULL* to create a new empty set. Return the new set on
|
|
|
|
success or *NULL* on failure. Raise :exc:`TypeError` if *iterable* is not
|
|
|
|
actually iterable. The constructor is also useful for copying a set
|
|
|
|
(``c=set(s)``).
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: PyObject* PyFrozenSet_New(PyObject *iterable)
|
|
|
|
|
|
|
|
Return a new :class:`frozenset` containing objects returned by the *iterable*.
|
|
|
|
The *iterable* may be *NULL* to create a new empty frozenset. Return the new
|
|
|
|
set on success or *NULL* on failure. Raise :exc:`TypeError` if *iterable* is
|
|
|
|
not actually iterable.
|
|
|
|
|
2008-01-28 16:34:33 -04:00
|
|
|
.. versionchanged:: 2.6
|
|
|
|
Now guaranteed to return a brand-new :class:`frozenset`. Formerly,
|
Merged revisions 68133-68134,68141-68142,68145-68146,68148-68149,68159-68162,68166,68171-68174,68179,68195-68196,68210,68214-68215,68217-68222 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r68133 | antoine.pitrou | 2009-01-01 16:38:03 +0100 (Thu, 01 Jan 2009) | 1 line
fill in actual issue number in tests
........
r68134 | hirokazu.yamamoto | 2009-01-01 16:45:39 +0100 (Thu, 01 Jan 2009) | 2 lines
Issue #4797: IOError.filename was not set when _fileio.FileIO failed to open
file with `str' filename on Windows.
........
r68141 | benjamin.peterson | 2009-01-01 17:43:12 +0100 (Thu, 01 Jan 2009) | 1 line
fix highlighting
........
r68142 | benjamin.peterson | 2009-01-01 18:29:49 +0100 (Thu, 01 Jan 2009) | 2 lines
welcome to 2009, Python!
........
r68145 | amaury.forgeotdarc | 2009-01-02 01:03:54 +0100 (Fri, 02 Jan 2009) | 5 lines
#4801 _collections module fails to build on cygwin.
_PyObject_GC_TRACK is the macro version of PyObject_GC_Track,
and according to documentation it should not be used for extension modules.
........
r68146 | ronald.oussoren | 2009-01-02 11:44:46 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue4472: "configure --enable-shared doesn't work on OSX"
........
r68148 | ronald.oussoren | 2009-01-02 11:48:31 +0100 (Fri, 02 Jan 2009) | 2 lines
Forgot to add a NEWS item in my previous checkin
........
r68149 | ronald.oussoren | 2009-01-02 11:50:48 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue4780
........
r68159 | ronald.oussoren | 2009-01-02 15:48:17 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue 1627952
........
r68160 | ronald.oussoren | 2009-01-02 15:52:09 +0100 (Fri, 02 Jan 2009) | 2 lines
Fix for issue r1737832
........
r68161 | ronald.oussoren | 2009-01-02 16:00:05 +0100 (Fri, 02 Jan 2009) | 3 lines
Fix for issue 1149804
........
r68162 | ronald.oussoren | 2009-01-02 16:06:00 +0100 (Fri, 02 Jan 2009) | 3 lines
Fix for issue 4472 is incompatible with Cygwin, this patch
should fix that.
........
r68166 | benjamin.peterson | 2009-01-02 19:26:23 +0100 (Fri, 02 Jan 2009) | 1 line
document PyMemberDef
........
r68171 | georg.brandl | 2009-01-02 21:25:14 +0100 (Fri, 02 Jan 2009) | 3 lines
#4811: fix markup glitches (mostly remains of the conversion),
found by Gabriel Genellina.
........
r68172 | martin.v.loewis | 2009-01-02 21:32:55 +0100 (Fri, 02 Jan 2009) | 2 lines
Issue #4075: Use OutputDebugStringW in Py_FatalError.
........
r68173 | martin.v.loewis | 2009-01-02 21:40:14 +0100 (Fri, 02 Jan 2009) | 2 lines
Issue #4051: Prevent conflict of UNICODE macros in cPickle.
........
r68174 | benjamin.peterson | 2009-01-02 21:47:27 +0100 (Fri, 02 Jan 2009) | 1 line
fix compilation on non-Windows platforms
........
r68179 | raymond.hettinger | 2009-01-02 22:26:45 +0100 (Fri, 02 Jan 2009) | 1 line
Issue #4615. Document how to use itertools for de-duping.
........
r68195 | georg.brandl | 2009-01-03 14:45:15 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove useless string literal.
........
r68196 | georg.brandl | 2009-01-03 15:29:53 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix indentation.
........
r68210 | georg.brandl | 2009-01-03 20:10:12 +0100 (Sat, 03 Jan 2009) | 2 lines
Set eol-style correctly for mp_distributing.py.
........
r68214 | georg.brandl | 2009-01-03 20:44:48 +0100 (Sat, 03 Jan 2009) | 2 lines
Make indentation consistent.
........
r68215 | georg.brandl | 2009-01-03 21:15:14 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix role name.
........
r68217 | georg.brandl | 2009-01-03 21:30:15 +0100 (Sat, 03 Jan 2009) | 2 lines
Add rstlint, a little tool to find subtle markup problems and inconsistencies in the Doc sources.
........
r68218 | georg.brandl | 2009-01-03 21:38:59 +0100 (Sat, 03 Jan 2009) | 2 lines
Recognize usage of the default role.
........
r68219 | georg.brandl | 2009-01-03 21:47:01 +0100 (Sat, 03 Jan 2009) | 2 lines
Fix uses of the default role.
........
r68220 | georg.brandl | 2009-01-03 21:55:06 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove trailing whitespace.
........
r68221 | georg.brandl | 2009-01-03 22:04:55 +0100 (Sat, 03 Jan 2009) | 2 lines
Remove tabs from the documentation.
........
r68222 | georg.brandl | 2009-01-03 22:11:58 +0100 (Sat, 03 Jan 2009) | 2 lines
Disable the line length checker by default.
........
2009-01-03 17:55:17 -04:00
|
|
|
frozensets of zero-length were a singleton. This got in the way of
|
2008-01-28 16:34:33 -04:00
|
|
|
building-up new frozensets with :meth:`PySet_Add`.
|
|
|
|
|
2008-01-19 18:08:21 -04:00
|
|
|
The following functions and macros are available for instances of :class:`set`
|
|
|
|
or :class:`frozenset` or instances of their subtypes.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: Py_ssize_t PySet_Size(PyObject *anyset)
|
|
|
|
|
|
|
|
.. index:: builtin: len
|
|
|
|
|
|
|
|
Return the length of a :class:`set` or :class:`frozenset` object. Equivalent to
|
|
|
|
``len(anyset)``. Raises a :exc:`PyExc_SystemError` if *anyset* is not a
|
|
|
|
:class:`set`, :class:`frozenset`, or an instance of a subtype.
|
|
|
|
|
Merged revisions 71873-71874,71882,71890,71893,71898-71900,71910,71914-71923,71925-71929,71931-71934,71937 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r71873 | jeroen.ruigrok | 2009-04-25 13:15:06 +0200 (za, 25 apr 2009) | 2 lines
Reformat prior to expanding.
........
r71874 | jeroen.ruigrok | 2009-04-25 13:59:09 +0200 (za, 25 apr 2009) | 2 lines
First attempt to document PyObject_HEAD_INIT and PyVarObject_HEAD_INIT.
........
r71882 | jeroen.ruigrok | 2009-04-25 14:49:10 +0200 (za, 25 apr 2009) | 3 lines
Issue #4239: adjust email examples not to use connect() and terminate with
quit() and not close().
........
r71890 | jeroen.ruigrok | 2009-04-25 15:07:40 +0200 (za, 25 apr 2009) | 3 lines
Rewrite a sentence to be more in line with the rest of the documentation with
regard to person and audience.
........
r71893 | jeroen.ruigrok | 2009-04-25 15:58:58 +0200 (za, 25 apr 2009) | 2 lines
Reformat file prior to editing.
........
r71898 | jeroen.ruigrok | 2009-04-25 16:24:30 +0200 (za, 25 apr 2009) | 2 lines
Reformat prior to editing.
........
r71899 | jeroen.ruigrok | 2009-04-25 16:27:00 +0200 (za, 25 apr 2009) | 3 lines
The type for ppos has been Py_ssize_t since 2.5, reflect this in the
documentation.
........
r71900 | jeroen.ruigrok | 2009-04-25 16:28:02 +0200 (za, 25 apr 2009) | 2 lines
Reformat paragraph.
........
r71910 | jeroen.ruigrok | 2009-04-25 19:59:03 +0200 (za, 25 apr 2009) | 4 lines
Issue #4129: Belatedly document which C API functions had their argument(s) or
return type changed from int or int * to Py_ssize_t or Py_ssize_t * as this
might cause problems on 64-bit platforms.
........
r71914 | jeroen.ruigrok | 2009-04-25 20:31:20 +0200 (za, 25 apr 2009) | 2 lines
Reformat prior to editing.
........
r71915 | jeroen.ruigrok | 2009-04-25 20:46:03 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: Document more int -> Py_ssize_t changes.
........
r71916 | jeroen.ruigrok | 2009-04-25 20:53:48 +0200 (za, 25 apr 2009) | 2 lines
Reformat prior to editing.
........
r71917 | jeroen.ruigrok | 2009-04-25 20:57:32 +0200 (za, 25 apr 2009) | 2 lines
Reference to an int type, whereas it's a Py_ssize_t as the synopsis states.
........
r71918 | jeroen.ruigrok | 2009-04-25 21:04:15 +0200 (za, 25 apr 2009) | 2 lines
Since I edited this file, reformat for future edits.
........
r71919 | jeroen.ruigrok | 2009-04-25 21:10:52 +0200 (za, 25 apr 2009) | 2 lines
Reformat prior to editing.
........
r71920 | jeroen.ruigrok | 2009-04-25 21:44:55 +0200 (za, 25 apr 2009) | 5 lines
Issue #4129: More documentation pointers about int -> Py_ssize_t.
Also fix up the documentation for PyObject_GC_Resize(). It seems that since
it first got documented, the documentation was actually for
_PyObject_GC_Resize().
........
r71921 | jeroen.ruigrok | 2009-04-25 21:46:19 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: Documentation notes for int -> Py_ssize_t changes.
........
r71922 | jeroen.ruigrok | 2009-04-25 21:49:05 +0200 (za, 25 apr 2009) | 2 lines
Reformat, since I've been busy here anyway.
........
r71923 | jeroen.ruigrok | 2009-04-25 21:54:34 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: Add a versionchanged notice for a few forgotten entries.
........
r71925 | jeroen.ruigrok | 2009-04-25 22:37:39 +0200 (za, 25 apr 2009) | 2 lines
Since it's a macro, actually refer to it as such instead of function.
........
r71926 | jeroen.ruigrok | 2009-04-25 22:40:10 +0200 (za, 25 apr 2009) | 2 lines
Reformat prior to editing.
........
r71927 | jeroen.ruigrok | 2009-04-25 22:41:40 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: int -> Py_ssize_t documentation.
........
r71928 | jeroen.ruigrok | 2009-04-25 22:43:30 +0200 (za, 25 apr 2009) | 2 lines
Reformat prior to editing.
........
r71929 | jeroen.ruigrok | 2009-04-25 22:44:58 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: int -> Py_ssize_t documentation.
........
r71931 | jeroen.ruigrok | 2009-04-25 22:50:27 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: int -> Py_ssize_t documentation.
........
r71932 | jeroen.ruigrok | 2009-04-25 22:55:39 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: more int -> Py_ssize_t documentation.
........
r71933 | jeroen.ruigrok | 2009-04-25 22:58:35 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: more int -> Py_ssize_t documentation.
........
r71934 | jeroen.ruigrok | 2009-04-25 23:02:34 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: field changed from int to Py_ssize_t.
........
r71937 | jeroen.ruigrok | 2009-04-25 23:16:05 +0200 (za, 25 apr 2009) | 2 lines
Issue #4129: document int -> Py_ssize_t changes.
........
2009-04-29 05:00:05 -03:00
|
|
|
.. versionchanged:: 2.5
|
|
|
|
This function returned an :ctype:`int`. This might require changes in
|
|
|
|
your code for properly supporting 64-bit systems.
|
|
|
|
|
2008-01-19 18:08:21 -04:00
|
|
|
|
|
|
|
.. cfunction:: Py_ssize_t PySet_GET_SIZE(PyObject *anyset)
|
|
|
|
|
|
|
|
Macro form of :cfunc:`PySet_Size` without error checking.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PySet_Contains(PyObject *anyset, PyObject *key)
|
|
|
|
|
|
|
|
Return 1 if found, 0 if not found, and -1 if an error is encountered. Unlike
|
|
|
|
the Python :meth:`__contains__` method, this function does not automatically
|
|
|
|
convert unhashable sets into temporary frozensets. Raise a :exc:`TypeError` if
|
|
|
|
the *key* is unhashable. Raise :exc:`PyExc_SystemError` if *anyset* is not a
|
|
|
|
:class:`set`, :class:`frozenset`, or an instance of a subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PySet_Add(PyObject *set, PyObject *key)
|
|
|
|
|
|
|
|
Add *key* to a :class:`set` instance. Does not apply to :class:`frozenset`
|
|
|
|
instances. Return 0 on success or -1 on failure. Raise a :exc:`TypeError` if
|
|
|
|
the *key* is unhashable. Raise a :exc:`MemoryError` if there is no room to grow.
|
|
|
|
Raise a :exc:`SystemError` if *set* is an not an instance of :class:`set` or its
|
|
|
|
subtype.
|
|
|
|
|
2008-01-28 16:34:33 -04:00
|
|
|
.. versionchanged:: 2.6
|
|
|
|
Now works with instances of :class:`frozenset` or its subtypes.
|
|
|
|
Like :cfunc:`PyTuple_SetItem` in that it can be used to fill-in the
|
|
|
|
values of brand new frozensets before they are exposed to other code.
|
|
|
|
|
|
|
|
The following functions are available for instances of :class:`set` or its
|
|
|
|
subtypes but not for instances of :class:`frozenset` or its subtypes.
|
|
|
|
|
2008-01-19 18:08:21 -04:00
|
|
|
|
|
|
|
.. cfunction:: int PySet_Discard(PyObject *set, PyObject *key)
|
|
|
|
|
|
|
|
Return 1 if found and removed, 0 if not found (no action taken), and -1 if an
|
|
|
|
error is encountered. Does not raise :exc:`KeyError` for missing keys. Raise a
|
|
|
|
:exc:`TypeError` if the *key* is unhashable. Unlike the Python :meth:`discard`
|
|
|
|
method, this function does not automatically convert unhashable sets into
|
|
|
|
temporary frozensets. Raise :exc:`PyExc_SystemError` if *set* is an not an
|
|
|
|
instance of :class:`set` or its subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: PyObject* PySet_Pop(PyObject *set)
|
|
|
|
|
|
|
|
Return a new reference to an arbitrary object in the *set*, and removes the
|
|
|
|
object from the *set*. Return *NULL* on failure. Raise :exc:`KeyError` if the
|
|
|
|
set is empty. Raise a :exc:`SystemError` if *set* is an not an instance of
|
|
|
|
:class:`set` or its subtype.
|
|
|
|
|
|
|
|
|
|
|
|
.. cfunction:: int PySet_Clear(PyObject *set)
|
|
|
|
|
|
|
|
Empty an existing set of all elements.
|