在 Python 中一切都是对象。如果要在 Python 中表示一个对象,除了定义 class 外还有哪些方式呢?我们今天就来盘点一下。
0x00 dict
字典或映射存储 KV 键值对,它对查找、插入和删除操作都有比较高效率。用一个 dict 对象可以非常容易的表示一个对象。 dict 的使用也 很灵活,可以修改、添加或删除属性。
>>> student={ 'name':'jack', 'age':18, 'height':170 } >>> student {'name': 'jack', 'age': 18, 'height': 170} # 查看属性 >>> student['name'] 'jack' # 添加属性 >>> student['score']=89.0 >>> student {'name': 'jack', 'age': 18, 'height': 170, 'score': 89.0} # 删除属性 >>> del student['height'] >>> student {'name': 'jack', 'age': 18, 'score': 89.0}
0x01 tuple
tuple 也可以表示一个对象,相对于 dict 来说, 它是不可变的,一旦创建就不能随意修改。 tuple 也只能通过下标来访问对象的属性,因此当属性比较多时使用起来没有 dict 方便。
# 对象属性为name、age、height >>> student=('jack',18,170.0) >>> student ('jack', 18, 170.0) >>> student[1] 18 # tuple不能修改 >>> student[2]=175.0 TypeError: 'tuple' object does not support item assignment
0x02 collections.namedtuple
顾名思义 namedtuple 就是命名元组。它是 tuple 数据类型的扩展,同样地一旦创建,它的元素也是不可变的。与普通元组相比命名元组可以通过“属性名”来访问元素。
>>> from collections import namedtuple >>> Point = namedtuple('Point','x,y,z') >>> p = Point(1,3,5) >>> p Point(x=1, y=3, z=5) >>> Point = namedtuple('Point','x y z') >>> p = Point(1,3,5) >>> p Point(x=1, y=3, z=5) >>> p.x 1 >>> p.y = 3.5 AttributeError: can't set attribute # 可以看出通过namedtuple定义对象,就是一个class类型的 >>> type(p) <class '__main__.Point'>
对于一个简单的对象,我们使用 namedtuple 很方便的来定义,它比定义一个普通 class 要有更好的空间性能。
0x03 来1源gaodai#ma#com搞*代#码1网type.NamedTuple
Python3.6 中新增了 type.NamedTuple 类,它与 collections.namedtuple 的操作是类似的。不过,要定义 NamedTuple 就稍微不一样了。
>>> from typing import NamedTuple # 定义Car类,继承于NamedTuple,并定义属性color、speed、autmatic >>> class Car(NamedTuple): color:str speed:float automatic:bool >>> car = Car('red',120.0,True) >>> car Car(color='red', speed=120.0, automatic=True) >>> type(car) <class '__main__.Car'> # tuple都是不可变的 >>> car.speed = 130.0 AttributeError: can't set attribute
0x04 types.SimpleNamespace
使用 SimpleNamespace 也可以很方便的定义对象。它的定义等价于
class SimpleNamespace: def __init__(self, **kwargs): self.__dict__.update(kwargs) def __repr__(self): keys = sorted(self.__dict__) items = ("{}={!r}".format(k, self.__dict__[k]) for k in keys) return "{}({})".format(type(self).__name__, ", ".join(items)) def __eq__(self, other): return self.__dict__ == other.__dict__