1:mod:`plistlib` --- Generate and parse Apple ``.plist`` files
2=============================================================
3
4.. module:: plistlib
5   :synopsis: Generate and parse Apple plist files.
6
7.. moduleauthor:: Jack Jansen
8.. sectionauthor:: Georg Brandl <georg@python.org>
9.. (harvested from docstrings in the original file)
10
11**Source code:** :source:`Lib/plistlib.py`
12
13.. index::
14   pair: plist; file
15   single: property list
16
17--------------
18
19This module provides an interface for reading and writing the "property list"
20files used by Apple, primarily on macOS and iOS. This module supports both binary
21and XML plist files.
22
23The property list (``.plist``) file format is a simple serialization supporting
24basic object types, like dictionaries, lists, numbers and strings.  Usually the
25top level object is a dictionary.
26
27To write out and to parse a plist file, use the :func:`dump` and
28:func:`load` functions.
29
30To work with plist data in bytes objects, use :func:`dumps`
31and :func:`loads`.
32
33Values can be strings, integers, floats, booleans, tuples, lists, dictionaries
34(but only with string keys), :class:`bytes`, :class:`bytearray`
35or :class:`datetime.datetime` objects.
36
37.. versionchanged:: 3.4
38   New API, old API deprecated.  Support for binary format plists added.
39
40.. versionchanged:: 3.8
41   Support added for reading and writing :class:`UID` tokens in binary plists as used
42   by NSKeyedArchiver and NSKeyedUnarchiver.
43
44.. versionchanged:: 3.9
45   Old API removed.
46
47.. seealso::
48
49   `PList manual page <https://developer.apple.com/library/content/documentation/Cocoa/Conceptual/PropertyLists/>`_
50      Apple's documentation of the file format.
51
52
53This module defines the following functions:
54
55.. function:: load(fp, \*, fmt=None, dict_type=dict)
56
57   Read a plist file. *fp* should be a readable and binary file object.
58   Return the unpacked root object (which usually is a
59   dictionary).
60
61   The *fmt* is the format of the file and the following values are valid:
62
63   * :data:`None`: Autodetect the file format
64
65   * :data:`FMT_XML`: XML file format
66
67   * :data:`FMT_BINARY`: Binary plist format
68
69   The *dict_type* is the type used for dictionaries that are read from the
70   plist file.
71
72   XML data for the :data:`FMT_XML` format is parsed using the Expat parser
73   from :mod:`xml.parsers.expat` -- see its documentation for possible
74   exceptions on ill-formed XML.  Unknown elements will simply be ignored
75   by the plist parser.
76
77   The parser for the binary format raises :exc:`InvalidFileException`
78   when the file cannot be parsed.
79
80   .. versionadded:: 3.4
81
82
83.. function:: loads(data, \*, fmt=None, dict_type=dict)
84
85   Load a plist from a bytes object. See :func:`load` for an explanation of
86   the keyword arguments.
87
88   .. versionadded:: 3.4
89
90
91.. function:: dump(value, fp, \*, fmt=FMT_XML, sort_keys=True, skipkeys=False)
92
93   Write *value* to a plist file. *Fp* should be a writable, binary
94   file object.
95
96   The *fmt* argument specifies the format of the plist file and can be
97   one of the following values:
98
99   * :data:`FMT_XML`: XML formatted plist file
100
101   * :data:`FMT_BINARY`: Binary formatted plist file
102
103   When *sort_keys* is true (the default) the keys for dictionaries will be
104   written to the plist in sorted order, otherwise they will be written in
105   the iteration order of the dictionary.
106
107   When *skipkeys* is false (the default) the function raises :exc:`TypeError`
108   when a key of a dictionary is not a string, otherwise such keys are skipped.
109
110   A :exc:`TypeError` will be raised if the object is of an unsupported type or
111   a container that contains objects of unsupported types.
112
113   An :exc:`OverflowError` will be raised for integer values that cannot
114   be represented in (binary) plist files.
115
116   .. versionadded:: 3.4
117
118
119.. function:: dumps(value, \*, fmt=FMT_XML, sort_keys=True, skipkeys=False)
120
121   Return *value* as a plist-formatted bytes object. See
122   the documentation for :func:`dump` for an explanation of the keyword
123   arguments of this function.
124
125   .. versionadded:: 3.4
126
127
128The following classes are available:
129
130.. class:: UID(data)
131
132   Wraps an :class:`int`.  This is used when reading or writing NSKeyedArchiver
133   encoded data, which contains UID (see PList manual).
134
135   It has one attribute, :attr:`data`, which can be used to retrieve the int value
136   of the UID.  :attr:`data` must be in the range `0 <= data < 2**64`.
137
138   .. versionadded:: 3.8
139
140
141The following constants are available:
142
143.. data:: FMT_XML
144
145   The XML format for plist files.
146
147   .. versionadded:: 3.4
148
149
150.. data:: FMT_BINARY
151
152   The binary format for plist files
153
154   .. versionadded:: 3.4
155
156
157Examples
158--------
159
160Generating a plist::
161
162    pl = dict(
163        aString = "Doodah",
164        aList = ["A", "B", 12, 32.1, [1, 2, 3]],
165        aFloat = 0.1,
166        anInt = 728,
167        aDict = dict(
168            anotherString = "<hello & hi there!>",
169            aThirdString = "M\xe4ssig, Ma\xdf",
170            aTrueValue = True,
171            aFalseValue = False,
172        ),
173        someData = b"<binary gunk>",
174        someMoreData = b"<lots of binary gunk>" * 10,
175        aDate = datetime.datetime.fromtimestamp(time.mktime(time.gmtime())),
176    )
177    with open(fileName, 'wb') as fp:
178        dump(pl, fp)
179
180Parsing a plist::
181
182    with open(fileName, 'rb') as fp:
183        pl = load(fp)
184    print(pl["aKey"])
185