ucollections – 收集和容器类型

简介

ucollections 模块实现了专门的容器数据类型,它提供了 Python 的通用内置容器的替代方案,包括了字典、列表、集合和元组。

ucollections.namedtuple(name, fields)

这是工厂函数创建一个新的 namedtuple 型与一个特定的字段名称和集合。namedtuple 是元组允许子类要访问它的字段不仅是数字索引,而且还具有属性使用符号字段名访问语法。 字段是字符串序列指定字段名称。为了兼容的实现也可以用空间分隔的字符串命名的字段(但效率较低) 。

代码示例:

  1. from ucollections import namedtuple
  2.  
  3. MyTuple = namedtuple("MyTuple", ("id", "name"))
  4. t1 = MyTuple(1, "foo")
  5. t2 = MyTuple(2, "bar")
  6. print(t1.name)
  7. assert t2.name == t2[1]
  8. ucollections.OrderedDict(...)

ucollections.OrderedDict(…)

字典类型的子类,会记住并保留键/值的追加顺序。当有序的字典被迭代输出时,键/值 会按照他们被添加的顺序返回 :

  1. from ucollections import OrderedDict
  2.  
  3. # To make benefit of ordered keys, OrderedDict should be initialized
  4. # from sequence of (key, value) pairs.
  5. d = OrderedDict([("z", 1), ("a", 2)])
  6. # More items can be added as usual
  7. d["w"] = 5
  8. d["b"] = 3
  9. for k, v in d.items():
  10. print(k, v)

输出:

z 1a 2w 5b 3

更多的内容可参考 ucollections


评论

原文: https://www.rt-thread.org/document/site/submodules/micropython/docs/03-Basic_Module/06-ucollections/