ucollections – 容器

该模块实现相应CPython模块的子集,如下所示。更多信息,请参见 |CPython文档| collections.

该模块实现高级集合和容器类型来保存/累积各种对象。

ucollections.deque(iterable, maxlen[, flags])

Deques(双端队列)是一个类似列表的容器,它支持O(1)从双端队列的任意一端追加和弹出。使用以下参数创建新双端队列:

  • iterable 必须是空的元组,并且新双端队列被创建为空。

  • maxlen 必须指定,双端队列将被限制到这个最大长度。一旦双端队列已满,添加任何新项目将丢弃另一端的项目。

  • 可选的 flags 可以是1,以检查添加项目时是否溢出。

除了支持 boollen 之外,双端队列对象还具有以下特性

methods:

deque.append(x)

将*x* 添加到双端队列的右侧。

如果启用了溢出检查,并且没有剩余空间,则引发IndexError。

deque.popleft()

从deque的左侧删除并返回一个item。 如果没有item存在,则引发IndexError。

ucollections.namedtuple(name, fields)

这是一个用以创建具有特定名称和字段集的新命名的元组类型的函数。命名元组为元组的子类, 它可以通过数值索引或具有符号字段名的属性访问语法来访问其字段。字段是指定字段名的字符串序列。 为实现与CPython的兼容,也可为一个带有空格分隔字段的字符串(但是这样效率较低)。 用法示例:

from ucollections import namedtuple

MyTuple = namedtuple("MyTuple", ("id", "name"))
t1 = MyTuple(1, "foo")
t2 = MyTuple(2, "bar")
print(t1.name)
assert t2.name == t2[1]
ucollections.OrderedDict(...)

dict 类型的子类,该子类记住并保存所添加键的顺序。当有序字典重复时,键/项将按照其添加的顺序返回:

from ucollections import OrderedDict

# To make benefit of ordered keys, OrderedDict should be initialized 为充分利用有序键,应将有序字典初始化
# from sequence of (key, value) pairs. 从序列对(键、值)中
d = OrderedDict([("z", 1), ("a", 2)])
# More items can be added as usual 可添加更多项
d["w"] = 5
d["b"] = 3
for k, v in d.items():
    print(k, v)

输出:

z 1
a 2
w 5
b 3