那就好好理清楚呗。
在大家开始探索如何写一个Pythonic对象之前,让大家先弄清楚这个术语的含义它不是关于PEP8和尊重其规则来编写漂亮的python代码;而是关于编写对象,最大限度地使用Python数据模型的概念,因此它们可以像Python标准库对象一样被自然地使用。
其思想是将Python ADN注入到大家的用户定义对象中,使它们发生变异,并表现为本地Python对象为此,大家将实现一个向量类来表示多维向量。
下面的代码用最小的实现表示Vector类。矢量由其坐标表示。
向量坐标存储在浮点数组中;请注意将数组中的元素类型强制设置为浮点的array type=“d”。大家可以将任何iterable传递给Vector的构造函数,因为数组的构造函数用作接受任何iterable(元组、列表等)的内部容器。
当大家打印一个向量对象本身时,注意大家得到它的引用(CPython的内存地址)而不是它的坐标。让大家通过在类中实现_str_方法来更改它,使其具有更友好的输出,例如(x,y,z,…)。
当大家打印一个向量对象本身时,注意大家得到它的引用(CPython的内存地址)而不是它的坐标。让大家通过在类中实现_str_方法来更改它,使其具有更友好的输出,例如(x,y,z,…)注意,大家使用了从数组创建的元组的字符串表示。
__str_不是Python数据模型用于打印对象的唯一方法;_repr_还用于提供更面向调试目的的对象表示可以计算此表示以使用eval函数创建相同的对象。
在前面的代码块中,请注意,与eval一起使用时repr的返回值允许创建新向量reprlib的使用允许大家在数组包含太多元素的情况下不打印数组的所有元素,并用就像向量v2。
Python迭代为了确保大家可以在向量上循环,并且可以将它们解包,大家需要使它们可迭代为此,必须向大家的类中添加_iter_方法。
Python长度计算为了能够通过将对象赋给len()函数来获得向量内的坐标数,必须将_Len_方法添加到类中。
Python的比较在不调整类以支持比较的情况下,应用于两个向量对象的==运算符将比较它们的引用。若要更改此行为,必须实现“eq”方法。在大家的例子中,两个向量是相等的,当且仅当它们具有相同的坐标且具有相同的顺序。
让大家花点时间分析一下新的方法:通过调用len()函数来使用len方法。
通过将self和其他参数传递给zip函数来使用iter方法,zip函数接受iterable作为参数。
Pythonic绝对值
对于此示例,大家使用该 __abs__ 方法返回由以下表达式定义的向量的欧几里得范数:
Pythonic布尔求值对于向量类的当前实现,大家在计算向量的布尔值时有以下行为。
在大家的类中,如果没有bool方法,对bool()函数的调用将引用该方法如果长度等于0,则对象的计算结果为false-否则,其计算结果为true。
让大家通过实现一个方法来改变这种行为,如果向量欧几里德范数与0不同,则让它返回True,否则返回false。
Pythonic切片
Python中的切片旨在通过指示要检索的元素的索引或通过指示切片,从初始集合中获取子集。
一个对象的切片返回同一类型的另一个对象。getitem方法是要更新的方法,以使向量对象具有这种能力。
注意,通过使用Slicing,返回的对象也是一个向量对象。
结论大家在本教程中实现的Dunder方法并不是唯一可以使用的方法其他的,如字节、散列、getatrr和格式可以用来改变用户定义对象的行为这些方法并不是每次定义新类时都要实现的,这取决于需要,这是Python数据模型的优点。
欢迎关注哦。