问题:了解__getitem__方法
我已经阅读了__getitem__
Python文档中的大多数文档,但仍然无法理解它的含义。
因此,我所能理解的__getitem__
就是用于实现类似的调用self[key]
。但是它有什么用?
可以说我以这种方式定义了一个python类:
class Person:
def __init__(self,name,age):
self.name = name
self.age = age
def __getitem__(self,key):
print ("Inside `__getitem__` method!")
return getattr(self,key)
p = Person("Subhayan",32)
print (p["age"])
这将返回预期的结果。但是为什么要__getitem__
首先使用?我还听说过Python __getitem__
内部调用。但是为什么要这样做呢?
有人可以详细解释一下吗?
回答 0
马聪(Cong Ma)很好地解释了__getitem__
用途-但我想举一个可能有用的示例。想象一个为建筑物建模的类。在建筑物数据中,它包含许多属性,包括对占据每个楼层的公司的描述:
如果不使用,__getitem__
我们将有一个像这样的类:
class Building(object):
def __init__(self, floors):
self._floors = [None]*floors
def occupy(self, floor_number, data):
self._floors[floor_number] = data
def get_floor_data(self, floor_number):
return self._floors[floor_number]
building1 = Building(4) # Construct a building with 4 floors
building1.occupy(0, 'Reception')
building1.occupy(1, 'ABC Corp')
building1.occupy(2, 'DEF Inc')
print( building1.get_floor_data(2) )
但是,我们可以使用__getitem__
(及其对应的__setitem__
)来使用Building类“ nicer”。
class Building(object):
def __init__(self, floors):
self._floors = [None]*floors
def __setitem__(self, floor_number, data):
self._floors[floor_number] = data
def __getitem__(self, floor_number):
return self._floors[floor_number]
building1 = Building(4) # Construct a building with 4 floors
building1[0] = 'Reception'
building1[1] = 'ABC Corp'
building1[2] = 'DEF Inc'
print( building1[2] )
是否__setitem__
像这样使用,实际上取决于您计划如何抽象化数据-在这种情况下,我们决定将建筑物视为楼层的容器(并且您还可以为建筑物实现迭代器,甚至可以实现切片功能-即一次获取多个楼层的数据-这取决于您的需求。
回答 1
[]
通过键或索引获取项目的语法仅仅是语法糖。
在评估a[i]
Python调用时a.__getitem__(i)
(或type(a).__getitem__(a, i)
,但是这种区别是关于继承模型的,在这里并不重要)。即使的类a
可能未明确定义此方法,它也通常是从祖先类继承的。
此处列出了所有(Python 2.7)特殊方法名称及其语义:https : //docs.python.org/2.7/reference/datamodel.html#special-method-names
回答 2
magic方法__getitem__
基本上用于访问列表项,字典条目,数组元素等。它对于快速查找实例属性非常有用。
在这里,我用一个示例类Person来显示这一点,该类可以通过“名称”,“年龄”和“出生日期”(出生日期)实例化。该__getitem__
方法以一种可以访问索引实例属性的方式编写,例如,名字或姓氏,日期,日期,月份或年份等。
import copy
# Constants that can be used to index date of birth's Date-Month-Year
D = 0; M = 1; Y = -1
class Person(object):
def __init__(self, name, age, dob):
self.name = name
self.age = age
self.dob = dob
def __getitem__(self, indx):
print ("Calling __getitem__")
p = copy.copy(self)
p.name = p.name.split(" ")[indx]
p.dob = p.dob[indx] # or, p.dob = p.dob.__getitem__(indx)
return p
假设一个用户输入如下:
p = Person(name = 'Jonab Gutu', age = 20, dob=(1, 1, 1999))
借助__getitem__
方法,用户可以访问索引属性。例如,
print p[0].name # print first (or last) name
print p[Y].dob # print (Date or Month or ) Year of the 'date of birth'