plistlib —- 生成与解析 Apple .plist 文件

源代码: Lib/plistlib.py


此模块提供了可读写 Apple “property list” 文件的接口,它主要用于 macOS 和 iOS 系统。 此模块同时支持二进制和 XML plist 文件。

property list (.plist) 文件格式是一种简单的序列化格式,它支持一些基本对象类型,例如字典、列表、数字和字符串等。 通常使用一个字典作为最高层级对象。

要写入和解析 plist 文件,请使用 dump()load() 函数。

要以字节串或字符串对象形式操作 plist 数据,请使用 dumps()loads()

值可以为字符串、整数、浮点数、布尔值、元组、列表、字典(但只允许用字符串作为键)、bytesbytearraydatetime.datetime 对象。

在 3.4 版本发生变更: 新版 API,旧版 API 已被弃用。 添加了对二进制 plist 格式的支持。

在 3.8 版本发生变更: 添加了在二进制 plist 中读写 UID 令牌的支持,例如用于 NSKeyedArchiver 和 NSKeyedUnarchiver。

在 3.9 版本发生变更: 旧 API 已被移除。

参见

PList 指南页面

针对该文件格式的 Apple 文档。

这个模块定义了以下函数:

plistlib.load(fp, *, fmt=None, dict_type=dict, aware_datetime=False)

读取 plist 文件。 fp 应当可读并且为二进制文件对象。 返回已解包的根对象(通常是一个字典)。

fmt 为文件的格式,有效的值如下:

dict_type 为字典用来从 plist 文件读取的类型。

aware_datetime 为真值时,类型为 datetime.datetime 的字段作为 感知型对象 被创建,其 tzinfo 将设为 datetime.UTC

FMT_XML 格式的 XML 数据 会使用来自 xml.parsers.expat 的 Expat 解析器 — 请参阅其文档了解错误格式 XML 可能引发的异常。 未知元素将被 plist 解析器直接略过。

当文件无法被解析时二进制格式的解析器将引发 InvalidFileException

Added in version 3.4.

在 3.13 版本发生变更: 增加了仅限关键字形参 aware_datetime

plistlib.loads(data, *, fmt=None, dict_type=dict, aware_datetime=False)

从一个字节串或字符串对象加载 plist。 请参阅 load() 获取相应关键字参数的说明。

Added in version 3.4.

在 3.13 版本发生变更: 当 fmt 等于 FMT_XMLdata 可以为字符串。

plistlib.dump(value, fp, *, fmt=FMT_XML, sort_keys=True, skipkeys=False, aware_datetime=False)

value 写入 plist 文件。 Fp 应当可写并且为二进制文件对象。

fmt 参数指定 plist 文件的格式,可以是以下值之一:

sort_keys 为真值(默认)时字典的键将经过排序再写入 plist,否则将按字典的迭代顺序写入。

skipkeys 为假值(默认)时该函数将在字典的键不为字符串时引发 TypeError,否则将跳过这样的键。

aware_datetime 为真值并且有任何类型为 datetime.datetime 的字段被设为 感知型对象,它将在写入之前转换为 UTC 时区。

如果对象是不受支持的类型或者是包含不受支持类型的对象的容器则将引发 TypeError

对于无法在(二进制)plist 文件中表示的整数值,将会引发 OverflowError

Added in version 3.4.

在 3.13 版本发生变更: 增加了仅限关键字形参 aware_datetime

plistlib.dumps(value, *, fmt=FMT_XML, sort_keys=True, skipkeys=False, aware_datetime=False)

value 以 plist 格式字节串对象的形式返回。 参阅 dump() 的文档获取此函数的关键字参数的说明。

Added in version 3.4.

可以使用以下的类:

class plistlib.UID(data)

包装一个 int。 该类将在读取或写入 NSKeyedArchiver 编码的数据时被使用,其中包含 UID(参见 PList 指南)。

它具有一个属性 data,可以被用来提取 UID 的 int 值。 data 的取值范围必须为 0 <= data < 2**64

Added in version 3.8.

可以使用以下的常量:

plistlib.FMT_XML

用于 plist 文件的 XML 格式。

Added in version 3.4.

plistlib.FMT_BINARY

用于 plist 文件的二进制格式。

Added in version 3.4.

例子

生成一个 plist:

  1. import datetime
  2. import plistlib
  3. pl = dict(
  4. aString = "Doodah",
  5. aList = ["A", "B", 12, 32.1, [1, 2, 3]],
  6. aFloat = 0.1,
  7. anInt = 728,
  8. aDict = dict(
  9. anotherString = "<hello & hi there!>",
  10. aThirdString = "M\xe4ssig, Ma\xdf",
  11. aTrueValue = True,
  12. aFalseValue = False,
  13. ),
  14. someData = b"<binary gunk>",
  15. someMoreData = b"<lots of binary gunk>" * 10,
  16. aDate = datetime.datetime.now()
  17. )
  18. print(plistlib.dumps(pl).decode())

解析一个 plist:

  1. import plistlib
  2. plist = b"""<plist version="1.0">
  3. <dict>
  4. <key>foo</key>
  5. <string>bar</string>
  6. </dict>
  7. </plist>"""
  8. pl = plistlib.loads(plist)
  9. print(pl["foo"])