51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

Python 元组

有些 Python 入门教程把元组称为"不可变列表",然而这并没有完全概括 元组的特点。除了用作不可变的列表,它还可以用于没有字段名的记 录。

元组 {#元组}

元组和记录 {#元组和记录}

元组其实是对数据的记录:元组中的每个元素都存放了记录中一个字段 的数据,外加这个字段的位置。正是这个位置信息给数据赋予了意义。

元组拆包 {#元组拆包}

上述示例中,我们把元组 ('Tokyo', 2003, 32450, 0.66, 8014) 里 的元素分别赋值给变量 city、year、pop、chg 和 area,而这所有的 赋值我们只用一行声明就写完了。同样,在后面一行中,一个 % 运算符 就把 passport 元组里的元素对应到了 print 函数的格式字符串空档 中。这两个都是对元组拆包的应用。

  • 可以交换变量值
  • 可以用 * 运算符拆开对象
  • 在元组拆包中使用 * 也可以帮助我们把注意力集中在元组的 部分元素上。
  • 是这个变量可以出 现在赋值表达式的任意位置:

嵌套元组拆包 {#嵌套元组拆包}

接受表达式的元组可以是嵌套式的,例如 (a, b, (c, d))。只要这个 接受元组的嵌套结构符合表达式本身的嵌套结构,Python 就可以作出正 确的对应。

具名元组 {#具名元组}

  • collections.namedtuple 是一个工厂函数,它可以用来构建一个带 字段名的元组和一个有名字的类------这个带名字的类对调试程序有很大帮助。
  1. 创建一个具名元组需要两个参数,一个是类名,另一个是类的各个字段的名字。后者可以是由数个字符串组成的可迭代对象,或者是由空格分隔开的字段名组成的字符串。

  2. 存放在对应字段里的数据要以一串参数的形式传入到构造函数中(注意,元组的构造函数却只接受单一的可迭代对象)。

  3. 你可以通过字段名或者位置来获取一个字段的信息。

  • 除了从普通元组那里继承来的属性之外,具名元组还有一些自己专有的 属性。其中几个最有用的:_fields 类属性、类方法 _make(iterable) 和实例方法 _asdict()。
  1. _fields 属性是一个包含这个类所有字段名称的元组。

  2. 用 _make() 通过接受一个可迭代对象来生成这个类的一个实例,它的作用跟 City(*delhi_data) 是一样的。

  3. _asdict() 把具名元组以 collections.OrderedDict 的形式返回,我们可以利用它来把元组里的信息友好地呈现出来。

不可变列表 {#不可变列表}

除了跟增减元素相关的方法之外,元组支 持列表的其他所有方法。还有一个例外,元组没有 reversed 方 法,但是这个方法只是个优化而已,reversed(my_tuple) 这个用法在 没有 reversed 的情况下也是合法的。

| | list | tuple | | |---------------------------|------|-------|--------------------------------------------| | s.__add__(s2) | √ | √ | s + s2,拼接 | | s.__iadd__(s2) | √ | | s += s2,就地拼接 | | s.append(e) | √ | | 在尾部添加一个新元素 | | s.clear() | √ | | 删除所有元素 | | s.__contains__(e) | √ | √ | s 是否包含 e | | s.copy() | √ | | 列表的浅复制 | | s.count(e) | √ | √ | e 在 s 中出现的次数 | | s.__delitem__(p) | √ | | 把位于 p 的元素删除 | | s.extend(it) | √ | | 把可迭代对象 it 追加给 s | | s.__getitem__(p) | √ | √ | s[p],获取位置 p 的元素 | | s.__getnewargs__() | √ | | 在 pickle 中支持更加优化的序列化 | | s.index(e) | √ | √ | 在 s 中找到元素 e 第一次出现的位置 | | s.insert(p, e) | √ | | 在位置 p 之前插入元素e | | s.__iter__() | √ | √ | 获取 s 的迭代器 | | s.__len__() | √ | √ | len(s),元素的数量 | | s.__mul__(n) | √ | √ | s * n,n 个 s 的重复拼接 | | s.__imul__(n) | √ | | s *= n,就地重复拼接 | | s.__rmul__(n) | √ | √ | n * s,反向拼接 * | | s.pop([p]) | √ | | 删除最后或者是(可选的)位于 p 的元素,并返回它的值 | | s.remove(e) | √ | | 删除 s 中的第一次出现的 e | | s.reverse() | √ | | 就地把 s 的元素倒序排列 | | s.__reversed__() | √ | | 返回 s 的倒序迭代器 | | s.__setitem__(p,e) | √ | | s[p] = e,把元素 e 放在位置p,替代已经在那个位置的元素 | | s.sort([key],[reverse]) | √ | | 就地对 s 中的元素进行排序,可选的参数有键(key) 和是否倒序(reverse) |

参考资料 {#参考资料}



文章链接:
https://www.zywvvd.com/notes/coding/python/fluent-python/chapter-2/tuple/tuple/

赞(0)
未经允许不得转载:工具盒子 » Python 元组