:mod:`json` --- JSON encoder and decoder ======================================== .. module:: json :synopsis: Encode and decode the JSON format. .. moduleauthor:: Bob Ippolito <bob@redivi.com> .. sectionauthor:: Bob Ippolito <bob@redivi.com> .. versionadded:: 2.6 `JSON (JavaScript Object Notation) <http://json.org>`_, specified by :rfc:`4627`, is a lightweight data interchange format based on a subset of `JavaScript <http://en.wikipedia.org/wiki/JavaScript>`_ syntax (`ECMA-262 3rd edition <http://www.ecma-international.org/publications/files/ECMA-ST-ARCH/ECMA-262,%203rd%20edition,%20December%201999.pdf>`_). :mod:`json` exposes an API familiar to users of the standard library :mod:`marshal` and :mod:`pickle` modules. Encoding basic Python object hierarchies:: >>> import json >>> json.dumps(['foo', {'bar': ('baz', None, 1.0, 2)}]) '["foo", {"bar": ["baz", null, 1.0, 2]}]' >>> print json.dumps("\"foo\bar") "\"foo\bar" >>> print json.dumps(u'\u1234') "\u1234" >>> print json.dumps('\\') "\\" >>> print json.dumps({"c": 0, "b": 0, "a": 0}, sort_keys=True) {"a": 0, "b": 0, "c": 0} >>> from StringIO import StringIO >>> io = StringIO() >>> json.dump(['streaming API'], io) >>> io.getvalue() '["streaming API"]' Compact encoding:: >>> import json >>> json.dumps([1,2,3,{'4': 5, '6': 7}], separators=(',',':')) '[1,2,3,{"4":5,"6":7}]' Pretty printing:: >>> import json >>> print json.dumps({'4': 5, '6': 7}, sort_keys=True, ... indent=4, separators=(',', ': ')) { "4": 5, "6": 7 } Decoding JSON:: >>> import json >>> json.loads('["foo", {"bar":["baz", null, 1.0, 2]}]') [u'foo', {u'bar': [u'baz', None, 1.0, 2]}] >>> json.loads('"\\"foo\\bar"') u'"foo\x08ar' >>> from StringIO import StringIO >>> io = StringIO('["streaming API"]') >>> json.load(io) [u'streaming API'] Specializing JSON object decoding:: >>> import json >>> def as_complex(dct): ... if '__complex__' in dct: ... return complex(dct['real'], dct['imag']) ... return dct ... >>> json.loads('{"__complex__": true, "real": 1, "imag": 2}', ... object_hook=as_complex) (1+2j) >>> import decimal >>> json.loads('1.1', parse_float=decimal.Decimal) Decimal('1.1') Extending :class:`JSONEncoder`:: >>> import json >>> class ComplexEncoder(json.JSONEncoder): ... def default(self, obj): ... if isinstance(obj, complex): ... return [obj.real, obj.imag] ... # Let the base class default method raise the TypeError ... return json.JSONEncoder.default(self, obj) ... >>> dumps(2 + 1j, cls=ComplexEncoder) '[2.0, 1.0]' >>> ComplexEncoder().encode(2 + 1j) '[2.0, 1.0]' >>> list(ComplexEncoder().iterencode(2 + 1j)) ['[', '2.0', ', ', '1.0', ']'] .. highlight:: none Using json.tool from the shell to validate and pretty-print:: $ echo '{"json":"obj"}' | python -mjson.tool { "json": "obj" } $ echo '{1.2:3.4}' | python -mjson.tool Expecting property name enclosed in double quotes: line 1 column 2 (char 1) .. highlight:: python .. note:: JSON is a subset of `YAML <http://yaml.org/>`_ 1.2. The JSON produced by this module's default settings (in particular, the default *separators* value) is also a subset of YAML 1.0 and 1.1. This module can thus also be used as a YAML serializer. Basic Usage ----------- .. function:: dump(obj, fp, skipkeys=False, ensure_ascii=True, \ check_circular=True, allow_nan=True, cls=None, \ indent=None, separators=None, encoding="utf-8", \ default=None, sort_keys=False, **kw) Serialize *obj* as a JSON formatted stream to *fp* (a ``.write()``-supporting :term:`file-like object`) using this :ref:`conversion table <py-to-json-table>`. If *skipkeys* is ``True`` (default: ``False``), then dict keys that are not of a basic type (:class:`str`, :class:`unicode`, :class:`int`, :class:`long`, :class:`float`, :class:`bool`, ``None``) will be skipped instead of raising a :exc:`TypeError`. If *ensure_ascii* is ``True`` (the default), all non-ASCII characters in the output are escaped with ``\uXXXX`` sequences, and the result is a :class:`str` instance consisting of ASCII characters only. If *ensure_ascii* is ``False``, some chunks written to *fp* may be :class:`unicode` instances. This usually happens because the input contains unicode strings or the *encoding* parameter is used. Unless ``fp.write()`` explicitly understands :class:`unicode` (as in :func:`codecs.getwriter`) this is likely to cause an error. If *check_circular* is ``False`` (default: ``True``), then the circular reference check for container types will be skipped and a circular reference will result in an :exc:`OverflowError` (or worse). If *allow_nan* is ``False`` (default: ``True``), then it will be a :exc:`ValueError` to serialize out of range :class:`float` values (``nan``, ``inf``, ``-inf``) in strict compliance of the JSON specification, instead of using the JavaScript equivalents (``NaN``, ``Infinity``, ``-Infinity``). If *indent* is a non-negative integer, then JSON array elements and object members will be pretty-printed with that indent level. An indent level of 0, or negative, will only insert newlines. ``None`` (the default) selects the most compact representation. .. note:: Since the default item separator is ``', '``, the output might include trailing whitespace when *indent* is specified. You can use ``separators=(',', ': ')`` to avoid this. If *separators* is an ``(item_separator, dict_separator)`` tuple, then it will be used instead of the default ``(', ', ': ')`` separators. ``(',', ':')`` is the most compact JSON representation. *encoding* is the character encoding for str instances, default is UTF-8. *default(obj)* is a function that should return a serializable version of *obj* or raise :exc:`TypeError`. The default simply raises :exc:`TypeError`. If *sort_keys* is ``True`` (default: ``False``), then the output of dictionaries will be sorted by key. To use a custom :class:`JSONEncoder` subclass (e.g. one that overrides the :meth:`default` method to serialize additional types), specify it with the *cls* kwarg; otherwise :class:`JSONEncoder` is used. .. note:: Unlike :mod:`pickle` and :mod:`marshal`, JSON is not a framed protocol so trying to serialize more objects with repeated calls to :func:`dump` and the same *fp* will result in an invalid JSON file. .. function:: dumps(obj, skipkeys=False, ensure_ascii=True, \ check_circular=True, allow_nan=True, cls=None, \ indent=None, separators=None, encoding="utf-8", \ default=None, sort_keys=False, **kw) Serialize *obj* to a JSON formatted :class:`str` using this :ref:`conversion table <py-to-json-table>`. If *ensure_ascii* is ``False``, the result may contain non-ASCII characters and the return value may be a :class:`unicode` instance. The arguments have the same meaning as in :func:`dump`. .. note:: Keys in key/value pairs of JSON are always of the type :class:`str`. When a dictionary is converted into JSON, all the keys of the dictionary are coerced to strings. As a result of this, if a dictionary is converted into JSON and then back into a dictionary, the dictionary may not equal the original one. That is, ``loads(dumps(x)) != x`` if x has non-string keys. .. function:: load(fp[, encoding[, cls[, object_hook[, parse_float[, parse_int[, parse_constant[, object_pairs_hook[, **kw]]]]]]]]) Deserialize *fp* (a ``.read()``-supporting :term:`file-like object` containing a JSON document) to a Python object using this :ref:`conversion table <json-to-py-table>`. If the contents of *fp* are encoded with an ASCII based encoding other than UTF-8 (e.g. latin-1), then an appropriate *encoding* name must be specified. Encodings that are not ASCII based (such as UCS-2) are not allowed, and should be wrapped with ``codecs.getreader(encoding)(fp)``, or simply decoded to a :class:`unicode` object and passed to :func:`loads`. *object_hook* is an optional function that will be called with the result of any object literal decoded (a :class:`dict`). The return value of *object_hook* will be used instead of the :class:`dict`. This feature can be used to implement custom decoders (e.g. `JSON-RPC <http://www.jsonrpc.org>`_ class hinting). *object_pairs_hook* is an optional function that will be called with the result of any object literal decoded with an ordered list of pairs. The return value of *object_pairs_hook* will be used instead of the :class:`dict`. This feature can be used to implement custom decoders that rely on the order that the key and value pairs are decoded (for example, :func:`collections.OrderedDict` will remember the order of insertion). If *object_hook* is also defined, the *object_pairs_hook* takes priority. .. versionchanged:: 2.7 Added support for *object_pairs_hook*. *parse_float*, if specified, will be called with the string of every JSON float to be decoded. By default, this is equivalent to ``float(num_str)``. This can be used to use another datatype or parser for JSON floats (e.g. :class:`decimal.Decimal`). *parse_int*, if specified, will be called with the string of every JSON int to be decoded. By default, this is equivalent to ``int(num_str)``. This can be used to use another datatype or parser for JSON integers (e.g. :class:`float`). *parse_constant*, if specified, will be called with one of the following strings: ``'-Infinity'``, ``'Infinity'``, ``'NaN'``. This can be used to raise an exception if invalid JSON numbers are encountered. .. versionchanged:: 2.7 *parse_constant* doesn't get called on 'null', 'true', 'false' anymore. To use a custom :class:`JSONDecoder` subclass, specify it with the ``cls`` kwarg; otherwise :class:`JSONDecoder` is used. Additional keyword arguments will be passed to the constructor of the class. .. function:: loads(s[, encoding[, cls[, object_hook[, parse_float[, parse_int[, parse_constant[, object_pairs_hook[, **kw]]]]]]]]) Deserialize *s* (a :class:`str` or :class:`unicode` instance containing a JSON document) to a Python object using this :ref:`conversion table <json-to-py-table>`. If *s* is a :class:`str` instance and is encoded with an ASCII based encoding other than UTF-8 (e.g. latin-1), then an appropriate *encoding* name must be specified. Encodings that are not ASCII based (such as UCS-2) are not allowed and should be decoded to :class:`unicode` first. The other arguments have the same meaning as in :func:`load`. Encoders and Decoders --------------------- .. class:: JSONDecoder([encoding[, object_hook[, parse_float[, parse_int[, parse_constant[, strict[, object_pairs_hook]]]]]]]) Simple JSON decoder. Performs the following translations in decoding by default: .. _json-to-py-table: +---------------+-------------------+ | JSON | Python | +===============+===================+ | object | dict | +---------------+-------------------+ | array | list | +---------------+-------------------+ | string | unicode | +---------------+-------------------+ | number (int) | int, long | +---------------+-------------------+ | number (real) | float | +---------------+-------------------+ | true | True | +---------------+-------------------+ | false | False | +---------------+-------------------+ | null | None | +---------------+-------------------+ It also understands ``NaN``, ``Infinity``, and ``-Infinity`` as their corresponding ``float`` values, which is outside the JSON spec. *encoding* determines the encoding used to interpret any :class:`str` objects decoded by this instance (UTF-8 by default). It has no effect when decoding :class:`unicode` objects. Note that currently only encodings that are a superset of ASCII work, strings of other encodings should be passed in as :class:`unicode`. *object_hook*, if specified, will be called with the result of every JSON object decoded and its return value will be used in place of the given :class:`dict`. This can be used to provide custom deserializations (e.g. to support JSON-RPC class hinting). *object_pairs_hook*, if specified will be called with the result of every JSON object decoded with an ordered list of pairs. The return value of *object_pairs_hook* will be used instead of the :class:`dict`. This feature can be used to implement custom decoders that rely on the order that the key and value pairs are decoded (for example, :func:`collections.OrderedDict` will remember the order of insertion). If *object_hook* is also defined, the *object_pairs_hook* takes priority. .. versionchanged:: 2.7 Added support for *object_pairs_hook*. *parse_float*, if specified, will be called with the string of every JSON float to be decoded. By default, this is equivalent to ``float(num_str)``. This can be used to use another datatype or parser for JSON floats (e.g. :class:`decimal.Decimal`). *parse_int*, if specified, will be called with the string of every JSON int to be decoded. By default, this is equivalent to ``int(num_str)``. This can be used to use another datatype or parser for JSON integers (e.g. :class:`float`). *parse_constant*, if specified, will be called with one of the following strings: ``'-Infinity'``, ``'Infinity'``, ``'NaN'``, ``'null'``, ``'true'``, ``'false'``. This can be used to raise an exception if invalid JSON numbers are encountered. If *strict* is ``False`` (``True`` is the default), then control characters will be allowed inside strings. Control characters in this context are those with character codes in the 0-31 range, including ``'\t'`` (tab), ``'\n'``, ``'\r'`` and ``'\0'``. .. method:: decode(s) Return the Python representation of *s* (a :class:`str` or :class:`unicode` instance containing a JSON document) .. method:: raw_decode(s) Decode a JSON document from *s* (a :class:`str` or :class:`unicode` beginning with a JSON document) and return a 2-tuple of the Python representation and the index in *s* where the document ended. This can be used to decode a JSON document from a string that may have extraneous data at the end. .. class:: JSONEncoder([skipkeys[, ensure_ascii[, check_circular[, allow_nan[, sort_keys[, indent[, separators[, encoding[, default]]]]]]]]]) Extensible JSON encoder for Python data structures. Supports the following objects and types by default: .. _py-to-json-table: +-------------------+---------------+ | Python | JSON | +===================+===============+ | dict | object | +-------------------+---------------+ | list, tuple | array | +-------------------+---------------+ | str, unicode | string | +-------------------+---------------+ | int, long, float | number | +-------------------+---------------+ | True | true | +-------------------+---------------+ | False | false | +-------------------+---------------+ | None | null | +-------------------+---------------+ To extend this to recognize other objects, subclass and implement a :meth:`default` method with another method that returns a serializable object for ``o`` if possible, otherwise it should call the superclass implementation (to raise :exc:`TypeError`). If *skipkeys* is ``False`` (the default), then it is a :exc:`TypeError` to attempt encoding of keys that are not str, int, long, float or None. If *skipkeys* is ``True``, such items are simply skipped. If *ensure_ascii* is ``True`` (the default), all non-ASCII characters in the output are escaped with ``\uXXXX`` sequences, and the results are :class:`str` instances consisting of ASCII characters only. If *ensure_ascii* is ``False``, a result may be a :class:`unicode` instance. This usually happens if the input contains unicode strings or the *encoding* parameter is used. If *check_circular* is ``True`` (the default), then lists, dicts, and custom encoded objects will be checked for circular references during encoding to prevent an infinite recursion (which would cause an :exc:`OverflowError`). Otherwise, no such check takes place. If *allow_nan* is ``True`` (the default), then ``NaN``, ``Infinity``, and ``-Infinity`` will be encoded as such. This behavior is not JSON specification compliant, but is consistent with most JavaScript based encoders and decoders. Otherwise, it will be a :exc:`ValueError` to encode such floats. If *sort_keys* is ``True`` (default ``False``), then the output of dictionaries will be sorted by key; this is useful for regression tests to ensure that JSON serializations can be compared on a day-to-day basis. If *indent* is a non-negative integer (it is ``None`` by default), then JSON array elements and object members will be pretty-printed with that indent level. An indent level of 0 will only insert newlines. ``None`` is the most compact representation. .. note:: Since the default item separator is ``', '``, the output might include trailing whitespace when *indent* is specified. You can use ``separators=(',', ': ')`` to avoid this. If specified, *separators* should be an ``(item_separator, key_separator)`` tuple. The default is ``(', ', ': ')``. To get the most compact JSON representation, you should specify ``(',', ':')`` to eliminate whitespace. If specified, *default* is a function that gets called for objects that can't otherwise be serialized. It should return a JSON encodable version of the object or raise a :exc:`TypeError`. If *encoding* is not ``None``, then all input strings will be transformed into unicode using that encoding prior to JSON-encoding. The default is UTF-8. .. method:: default(o) Implement this method in a subclass such that it returns a serializable object for *o*, or calls the base implementation (to raise a :exc:`TypeError`). For example, to support arbitrary iterators, you could implement default like this:: def default(self, o): try: iterable = iter(o) except TypeError: pass else: return list(iterable) # Let the base class default method raise the TypeError return JSONEncoder.default(self, o) .. method:: encode(o) Return a JSON string representation of a Python data structure, *o*. For example:: >>> JSONEncoder().encode({"foo": ["bar", "baz"]}) '{"foo": ["bar", "baz"]}' .. method:: iterencode(o) Encode the given object, *o*, and yield each string representation as available. For example:: for chunk in JSONEncoder().iterencode(bigobject): mysocket.write(chunk) Standard Compliance ------------------- The JSON format is specified by :rfc:`4627`. This section details this module's level of compliance with the RFC. For simplicity, :class:`JSONEncoder` and :class:`JSONDecoder` subclasses, and parameters other than those explicitly mentioned, are not considered. This module does not comply with the RFC in a strict fashion, implementing some extensions that are valid JavaScript but not valid JSON. In particular: - Top-level non-object, non-array values are accepted and output; - Infinite and NaN number values are accepted and output; - Repeated names within an object are accepted, and only the value of the last name-value pair is used. Since the RFC permits RFC-compliant parsers to accept input texts that are not RFC-compliant, this module's deserializer is technically RFC-compliant under default settings. Character Encodings ^^^^^^^^^^^^^^^^^^^ The RFC recommends that JSON be represented using either UTF-8, UTF-16, or UTF-32, with UTF-8 being the default. Accordingly, this module uses UTF-8 as the default for its *encoding* parameter. This module's deserializer only directly works with ASCII-compatible encodings; UTF-16, UTF-32, and other ASCII-incompatible encodings require the use of workarounds described in the documentation for the deserializer's *encoding* parameter. The RFC also non-normatively describes a limited encoding detection technique for JSON texts; this module's deserializer does not implement this or any other kind of encoding detection. As permitted, though not required, by the RFC, this module's serializer sets *ensure_ascii=True* by default, thus escaping the output so that the resulting strings only contain ASCII characters. Top-level Non-Object, Non-Array Values ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The RFC specifies that the top-level value of a JSON text must be either a JSON object or array (Python :class:`dict` or :class:`list`). This module's deserializer also accepts input texts consisting solely of a JSON null, boolean, number, or string value:: >>> just_a_json_string = '"spam and eggs"' # Not by itself a valid JSON text >>> json.loads(just_a_json_string) u'spam and eggs' This module itself does not include a way to request that such input texts be regarded as illegal. Likewise, this module's serializer also accepts single Python :data:`None`, :class:`bool`, numeric, and :class:`str` values as input and will generate output texts consisting solely of a top-level JSON null, boolean, number, or string value without raising an exception:: >>> neither_a_list_nor_a_dict = u"spam and eggs" >>> json.dumps(neither_a_list_nor_a_dict) # The result is not a valid JSON text '"spam and eggs"' This module's serializer does not itself include a way to enforce the aforementioned constraint. Infinite and NaN Number Values ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The RFC does not permit the representation of infinite or NaN number values. Despite that, by default, this module accepts and outputs ``Infinity``, ``-Infinity``, and ``NaN`` as if they were valid JSON number literal values:: >>> # Neither of these calls raises an exception, but the results are not valid JSON >>> json.dumps(float('-inf')) '-Infinity' >>> json.dumps(float('nan')) 'NaN' >>> # Same when deserializing >>> json.loads('-Infinity') -inf >>> json.loads('NaN') nan In the serializer, the *allow_nan* parameter can be used to alter this behavior. In the deserializer, the *parse_constant* parameter can be used to alter this behavior. Repeated Names Within an Object ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ The RFC specifies that the names within a JSON object should be unique, but does not specify how repeated names in JSON objects should be handled. By default, this module does not raise an exception; instead, it ignores all but the last name-value pair for a given name:: >>> weird_json = '{"x": 1, "x": 2, "x": 3}' >>> json.loads(weird_json) {u'x': 3} The *object_pairs_hook* parameter can be used to alter this behavior.
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
2to3.txt | File | 12.37 KB | 0644 |
|
__builtin__.txt | File | 1.45 KB | 0644 |
|
__future__.txt | File | 4.84 KB | 0644 |
|
__main__.txt | File | 535 B | 0644 |
|
_winreg.txt | File | 22.76 KB | 0644 |
|
abc.txt | File | 6.99 KB | 0644 |
|
aepack.txt | File | 4.16 KB | 0644 |
|
aetools.txt | File | 3.45 KB | 0644 |
|
aetypes.txt | File | 4.16 KB | 0644 |
|
aifc.txt | File | 6.91 KB | 0644 |
|
al.txt | File | 5.18 KB | 0644 |
|
allos.txt | File | 695 B | 0644 |
|
anydbm.txt | File | 3.87 KB | 0644 |
|
archiving.txt | File | 424 B | 0644 |
|
argparse.txt | File | 68.77 KB | 0644 |
|
array.txt | File | 10.4 KB | 0644 |
|
ast.txt | File | 9.7 KB | 0644 |
|
asynchat.txt | File | 8.99 KB | 0644 |
|
asyncore.txt | File | 12.37 KB | 0644 |
|
atexit.txt | File | 3.81 KB | 0644 |
|
audioop.txt | File | 10.15 KB | 0644 |
|
autogil.txt | File | 1015 B | 0644 |
|
base64.txt | File | 5.93 KB | 0644 |
|
basehttpserver.txt | File | 9.98 KB | 0644 |
|
bastion.txt | File | 2.55 KB | 0644 |
|
bdb.txt | File | 12.14 KB | 0644 |
|
binascii.txt | File | 6.04 KB | 0644 |
|
binhex.txt | File | 1.87 KB | 0644 |
|
bisect.txt | File | 5.29 KB | 0644 |
|
bsddb.txt | File | 7.4 KB | 0644 |
|
bz2.txt | File | 7.72 KB | 0644 |
|
calendar.txt | File | 11.01 KB | 0644 |
|
carbon.txt | File | 15.58 KB | 0644 |
|
cd.txt | File | 11.69 KB | 0644 |
|
cgi.txt | File | 22.12 KB | 0644 |
|
cgihttpserver.txt | File | 2.72 KB | 0644 |
|
cgitb.txt | File | 2.81 KB | 0644 |
|
chunk.txt | File | 4.82 KB | 0644 |
|
cmath.txt | File | 7.45 KB | 0644 |
|
cmd.txt | File | 8.14 KB | 0644 |
|
code.txt | File | 6.93 KB | 0644 |
|
codecs.txt | File | 63.19 KB | 0644 |
|
codeop.txt | File | 3.69 KB | 0644 |
|
collections.txt | File | 40.08 KB | 0644 |
|
colorpicker.txt | File | 913 B | 0644 |
|
colorsys.txt | File | 1.78 KB | 0644 |
|
commands.txt | File | 2.53 KB | 0644 |
|
compileall.txt | File | 4.49 KB | 0644 |
|
compiler.txt | File | 36.59 KB | 0644 |
|
configparser.txt | File | 19 KB | 0644 |
|
constants.txt | File | 2.18 KB | 0644 |
|
contextlib.txt | File | 5.36 KB | 0644 |
|
cookie.txt | File | 9.3 KB | 0644 |
|
cookielib.txt | File | 27.09 KB | 0644 |
|
copy.txt | File | 3.29 KB | 0644 |
|
copy_reg.txt | File | 2.27 KB | 0644 |
|
crypt.txt | File | 2.24 KB | 0644 |
|
crypto.txt | File | 771 B | 0644 |
|
csv.txt | File | 21.07 KB | 0644 |
|
ctypes.txt | File | 86.41 KB | 0644 |
|
curses.ascii.txt | File | 8.8 KB | 0644 |
|
curses.panel.txt | File | 2.68 KB | 0644 |
|
curses.txt | File | 70.87 KB | 0644 |
|
custominterp.txt | File | 570 B | 0644 |
|
datatypes.txt | File | 864 B | 0644 |
|
datetime.txt | File | 68.78 KB | 0644 |
|
dbhash.txt | File | 3.77 KB | 0644 |
|
dbm.txt | File | 2.89 KB | 0644 |
|
debug.txt | File | 446 B | 0644 |
|
decimal.txt | File | 68.95 KB | 0644 |
|
development.txt | File | 640 B | 0644 |
|
difflib.txt | File | 29.85 KB | 0644 |
|
dircache.txt | File | 1.77 KB | 0644 |
|
dis.txt | File | 20.82 KB | 0644 |
|
distutils.txt | File | 1.13 KB | 0644 |
|
dl.txt | File | 3.31 KB | 0644 |
|
doctest.txt | File | 71.42 KB | 0644 |
|
docxmlrpcserver.txt | File | 3.66 KB | 0644 |
|
dumbdbm.txt | File | 2.62 KB | 0644 |
|
dummy_thread.txt | File | 1.03 KB | 0644 |
|
dummy_threading.txt | File | 799 B | 0644 |
|
easydialogs.txt | File | 10.1 KB | 0644 |
|
email-examples.txt | File | 1.24 KB | 0644 |
|
email.charset.txt | File | 9.42 KB | 0644 |
|
email.encoders.txt | File | 2.32 KB | 0644 |
|
email.errors.txt | File | 3.73 KB | 0644 |
|
email.generator.txt | File | 5.99 KB | 0644 |
|
email.header.txt | File | 7.35 KB | 0644 |
|
email.iterators.txt | File | 2.28 KB | 0644 |
|
email.message.txt | File | 24.56 KB | 0644 |
|
email.mime.txt | File | 9.42 KB | 0644 |
|
email.parser.txt | File | 9.71 KB | 0644 |
|
email.txt | File | 14.61 KB | 0644 |
|
email.util.txt | File | 6.43 KB | 0644 |
|
errno.txt | File | 6.55 KB | 0644 |
|
exceptions.txt | File | 18.01 KB | 0644 |
|
fcntl.txt | File | 6.65 KB | 0644 |
|
filecmp.txt | File | 5.22 KB | 0644 |
|
fileformats.txt | File | 302 B | 0644 |
|
fileinput.txt | File | 7.06 KB | 0644 |
|
filesys.txt | File | 806 B | 0644 |
|
fl.txt | File | 17.23 KB | 0644 |
|
fm.txt | File | 2.64 KB | 0644 |
|
fnmatch.txt | File | 3.03 KB | 0644 |
|
formatter.txt | File | 12.92 KB | 0644 |
|
fpectl.txt | File | 4.07 KB | 0644 |
|
fpformat.txt | File | 1.71 KB | 0644 |
|
fractions.txt | File | 5.17 KB | 0644 |
|
framework.txt | File | 11.18 KB | 0644 |
|
frameworks.txt | File | 378 B | 0644 |
|
ftplib.txt | File | 14.79 KB | 0644 |
|
functions.txt | File | 72.74 KB | 0644 |
|
functools.txt | File | 7.15 KB | 0644 |
|
future_builtins.txt | File | 1.86 KB | 0644 |
|
gc.txt | File | 8.76 KB | 0644 |
|
gdbm.txt | File | 4.71 KB | 0644 |
|
gensuitemodule.txt | File | 3.04 KB | 0644 |
|
getopt.txt | File | 6.51 KB | 0644 |
|
getpass.txt | File | 1.9 KB | 0644 |
|
gettext.txt | File | 28.35 KB | 0644 |
|
gl.txt | File | 5.87 KB | 0644 |
|
glob.txt | File | 2.31 KB | 0644 |
|
grp.txt | File | 2.2 KB | 0644 |
|
gzip.txt | File | 4.62 KB | 0644 |
|
hashlib.txt | File | 5.01 KB | 0644 |
|
heapq.txt | File | 12.64 KB | 0644 |
|
hmac.txt | File | 1.82 KB | 0644 |
|
hotshot.txt | File | 4.19 KB | 0644 |
|
htmllib.txt | File | 7.03 KB | 0644 |
|
htmlparser.txt | File | 11.34 KB | 0644 |
|
httplib.txt | File | 35.65 KB | 0644 |
|
i18n.txt | File | 409 B | 0644 |
|
ic.txt | File | 4.89 KB | 0644 |
|
idle.txt | File | 7.88 KB | 0644 |
|
imageop.txt | File | 3.91 KB | 0644 |
|
imaplib.txt | File | 16.77 KB | 0644 |
|
imgfile.txt | File | 2.7 KB | 0644 |
|
imghdr.txt | File | 2.57 KB | 0644 |
|
imp.txt | File | 12.3 KB | 0644 |
|
importlib.txt | File | 1.1 KB | 0644 |
|
imputil.txt | File | 6.86 KB | 0644 |
|
index.txt | File | 2.23 KB | 0644 |
|
inspect.txt | File | 27.21 KB | 0644 |
|
internet.txt | File | 950 B | 0644 |
|
intro.txt | File | 2.74 KB | 0644 |
|
io.txt | File | 36.31 KB | 0644 |
|
ipc.txt | File | 631 B | 0644 |
|
itertools.txt | File | 34.69 KB | 0644 |
|
jpeg.txt | File | 3.77 KB | 0644 |
|
json.txt | File | 23.39 KB | 0644 |
|
keyword.txt | File | 617 B | 0644 |
|
language.txt | File | 523 B | 0644 |
|
linecache.txt | File | 1.84 KB | 0644 |
|
locale.txt | File | 24.19 KB | 0644 |
|
logging.config.txt | File | 29.76 KB | 0644 |
|
logging.handlers.txt | File | 26.45 KB | 0644 |
|
logging.txt | File | 43.67 KB | 0644 |
|
mac.txt | File | 791 B | 0644 |
|
macos.txt | File | 3.73 KB | 0644 |
|
macosa.txt | File | 3.87 KB | 0644 |
|
macostools.txt | File | 3.92 KB | 0644 |
|
macpath.txt | File | 650 B | 0644 |
|
mailbox.txt | File | 66.51 KB | 0644 |
|
mailcap.txt | File | 3.59 KB | 0644 |
|
markup.txt | File | 1.22 KB | 0644 |
|
marshal.txt | File | 5.47 KB | 0644 |
|
math.txt | File | 10.64 KB | 0644 |
|
md5.txt | File | 2.75 KB | 0644 |
|
mhlib.txt | File | 3.87 KB | 0644 |
|
mimetools.txt | File | 4.4 KB | 0644 |
|
mimetypes.txt | File | 9.3 KB | 0644 |
|
mimewriter.txt | File | 3.2 KB | 0644 |
|
mimify.txt | File | 3.44 KB | 0644 |
|
miniaeframe.txt | File | 2.5 KB | 0644 |
|
misc.txt | File | 248 B | 0644 |
|
mm.txt | File | 447 B | 0644 |
|
mmap.txt | File | 10.02 KB | 0644 |
|
modulefinder.txt | File | 3.3 KB | 0644 |
|
modules.txt | File | 382 B | 0644 |
|
msilib.txt | File | 18.94 KB | 0644 |
|
msvcrt.txt | File | 4.24 KB | 0644 |
|
multifile.txt | File | 6.46 KB | 0644 |
|
multiprocessing.txt | File | 79.92 KB | 0644 |
|
mutex.txt | File | 1.89 KB | 0644 |
|
netdata.txt | File | 432 B | 0644 |
|
netrc.txt | File | 2.54 KB | 0644 |
|
new.txt | File | 2.59 KB | 0644 |
|
nis.txt | File | 2.06 KB | 0644 |
|
nntplib.txt | File | 14.18 KB | 0644 |
|
numbers.txt | File | 7.82 KB | 0644 |
|
numeric.txt | File | 751 B | 0644 |
|
operator.txt | File | 21.57 KB | 0644 |
|
optparse.txt | File | 75.22 KB | 0644 |
|
os.path.txt | File | 12.45 KB | 0644 |
|
os.txt | File | 79.94 KB | 0644 |
|
ossaudiodev.txt | File | 16.9 KB | 0644 |
|
othergui.txt | File | 2.73 KB | 0644 |
|
parser.txt | File | 15.02 KB | 0644 |
|
pdb.txt | File | 15.61 KB | 0644 |
|
persistence.txt | File | 826 B | 0644 |
|
pickle.txt | File | 36.25 KB | 0644 |
|
pickletools.txt | File | 1.95 KB | 0644 |
|
pipes.txt | File | 3.7 KB | 0644 |
|
pkgutil.txt | File | 7.53 KB | 0644 |
|
platform.txt | File | 9.15 KB | 0644 |
|
plistlib.txt | File | 4.02 KB | 0644 |
|
popen2.txt | File | 6.86 KB | 0644 |
|
poplib.txt | File | 6.07 KB | 0644 |
|
posix.txt | File | 3.51 KB | 0644 |
|
posixfile.txt | File | 7.03 KB | 0644 |
|
pprint.txt | File | 8.86 KB | 0644 |
|
profile.txt | File | 27.81 KB | 0644 |
|
pty.txt | File | 1.72 KB | 0644 |
|
pwd.txt | File | 2.66 KB | 0644 |
|
py_compile.txt | File | 2.42 KB | 0644 |
|
pyclbr.txt | File | 3.22 KB | 0644 |
|
pydoc.txt | File | 3.34 KB | 0644 |
|
pyexpat.txt | File | 27.83 KB | 0644 |
|
python.txt | File | 531 B | 0644 |
|
queue.txt | File | 6.8 KB | 0644 |
|
quopri.txt | File | 2.61 KB | 0644 |
|
random.txt | File | 12.71 KB | 0644 |
|
re.txt | File | 51.28 KB | 0644 |
|
readline.txt | File | 7.08 KB | 0644 |
|
repr.txt | File | 4.57 KB | 0644 |
|
resource.txt | File | 9.61 KB | 0644 |
|
restricted.txt | File | 3.24 KB | 0644 |
|
rexec.txt | File | 11.47 KB | 0644 |
|
rfc822.txt | File | 13.71 KB | 0644 |
|
rlcompleter.txt | File | 2.44 KB | 0644 |
|
robotparser.txt | File | 2.14 KB | 0644 |
|
runpy.txt | File | 6.46 KB | 0644 |
|
sched.txt | File | 4.49 KB | 0644 |
|
scrolledtext.txt | File | 1.32 KB | 0644 |
|
select.txt | File | 20.17 KB | 0644 |
|
sets.txt | File | 14.54 KB | 0644 |
|
sgi.txt | File | 322 B | 0644 |
|
sgmllib.txt | File | 10.41 KB | 0644 |
|
sha.txt | File | 2.74 KB | 0644 |
|
shelve.txt | File | 7.96 KB | 0644 |
|
shlex.txt | File | 10.82 KB | 0644 |
|
shutil.txt | File | 12.88 KB | 0644 |
|
signal.txt | File | 10.33 KB | 0644 |
|
simplehttpserver.txt | File | 4.34 KB | 0644 |
|
simplexmlrpcserver.txt | File | 9.7 KB | 0644 |
|
site.txt | File | 7.4 KB | 0644 |
|
smtpd.txt | File | 2.31 KB | 0644 |
|
smtplib.txt | File | 14.1 KB | 0644 |
|
sndhdr.txt | File | 1.72 KB | 0644 |
|
socket.txt | File | 39.7 KB | 0644 |
|
socketserver.txt | File | 20.12 KB | 0644 |
|
someos.txt | File | 599 B | 0644 |
|
spwd.txt | File | 2.76 KB | 0644 |
|
sqlite3.txt | File | 34.28 KB | 0644 |
|
ssl.txt | File | 27.8 KB | 0644 |
|
stat.txt | File | 7.59 KB | 0644 |
|
statvfs.txt | File | 1.27 KB | 0644 |
|
stdtypes.txt | File | 115.81 KB | 0644 |
|
string.txt | File | 42.78 KB | 0644 |
|
stringio.txt | File | 4 KB | 0644 |
|
stringprep.txt | File | 4.15 KB | 0644 |
|
strings.txt | File | 746 B | 0644 |
|
struct.txt | File | 16.7 KB | 0644 |
|
subprocess.txt | File | 32.68 KB | 0644 |
|
sun.txt | File | 249 B | 0644 |
|
sunau.txt | File | 6.96 KB | 0644 |
|
sunaudio.txt | File | 5.71 KB | 0644 |
|
symbol.txt | File | 975 B | 0644 |
|
symtable.txt | File | 4.89 KB | 0644 |
|
sys.txt | File | 45.76 KB | 0644 |
|
sysconfig.txt | File | 7.38 KB | 0644 |
|
syslog.txt | File | 3.84 KB | 0644 |
|
tabnanny.txt | File | 1.97 KB | 0644 |
|
tarfile.txt | File | 26.51 KB | 0644 |
|
telnetlib.txt | File | 7.31 KB | 0644 |
|
tempfile.txt | File | 10.23 KB | 0644 |
|
termios.txt | File | 3.66 KB | 0644 |
|
test.txt | File | 17.06 KB | 0644 |
|
textwrap.txt | File | 8.35 KB | 0644 |
|
thread.txt | File | 6.59 KB | 0644 |
|
threading.txt | File | 31.1 KB | 0644 |
|
time.txt | File | 24.79 KB | 0644 |
|
timeit.txt | File | 11.25 KB | 0644 |
|
tix.txt | File | 22.17 KB | 0644 |
|
tk.txt | File | 1.57 KB | 0644 |
|
tkinter.txt | File | 30.56 KB | 0644 |
|
token.txt | File | 2.39 KB | 0644 |
|
tokenize.txt | File | 5 KB | 0644 |
|
trace.txt | File | 6.57 KB | 0644 |
|
traceback.txt | File | 10.45 KB | 0644 |
|
ttk.txt | File | 56.02 KB | 0644 |
|
tty.txt | File | 1011 B | 0644 |
|
turtle.txt | File | 62.57 KB | 0644 |
|
types.txt | File | 6.04 KB | 0644 |
|
undoc.txt | File | 6.4 KB | 0644 |
|
unicodedata.txt | File | 5.59 KB | 0644 |
|
unittest.txt | File | 80.78 KB | 0644 |
|
unix.txt | File | 490 B | 0644 |
|
urllib.txt | File | 22.47 KB | 0644 |
|
urllib2.txt | File | 33.13 KB | 0644 |
|
urlparse.txt | File | 15.61 KB | 0644 |
|
user.txt | File | 2.68 KB | 0644 |
|
userdict.txt | File | 8.69 KB | 0644 |
|
uu.txt | File | 2.31 KB | 0644 |
|
uuid.txt | File | 8.17 KB | 0644 |
|
warnings.txt | File | 19.32 KB | 0644 |
|
wave.txt | File | 4.93 KB | 0644 |
|
weakref.txt | File | 12.66 KB | 0644 |
|
webbrowser.txt | File | 8.97 KB | 0644 |
|
whichdb.txt | File | 931 B | 0644 |
|
windows.txt | File | 273 B | 0644 |
|
winsound.txt | File | 4.87 KB | 0644 |
|
wsgiref.txt | File | 29.84 KB | 0644 |
|
xdrlib.txt | File | 7.89 KB | 0644 |
|
xml.dom.minidom.txt | File | 10.91 KB | 0644 |
|
xml.dom.pulldom.txt | File | 1.53 KB | 0644 |
|
xml.dom.txt | File | 39.2 KB | 0644 |
|
xml.etree.elementtree.txt | File | 31.82 KB | 0644 |
|
xml.sax.handler.txt | File | 14.93 KB | 0644 |
|
xml.sax.reader.txt | File | 11.65 KB | 0644 |
|
xml.sax.txt | File | 6.06 KB | 0644 |
|
xml.sax.utils.txt | File | 3.4 KB | 0644 |
|
xml.txt | File | 5.56 KB | 0644 |
|
xmlrpclib.txt | File | 21.4 KB | 0644 |
|
zipfile.txt | File | 17.22 KB | 0644 |
|
zipimport.txt | File | 5.78 KB | 0644 |
|
zlib.txt | File | 10.13 KB | 0644 |
|