- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
operator.itemgetter()函数是这样工作的:
>>> import operator
>>> getseconditem = operator.itemgetter(1)
>>> ls = ['a', 'b', 'c', 'd']
>>> getseconditem(ls)
'b'
编辑我添加了这部分以突出不一致
>>> def myitemgetter(item):
... def g(obj):
... return obj[item]
... return g
>>> mygetseconditem = myitemgetter(1)
现在,我有这门课
>>> class Items(object):
... second = getseconditem
... mysecond = mygetseconditem
...
... def __init__(self, *items):
... self.items = items
...
... def __getitem__(self, i):
... return self.items[i]
访问第二个项目及其索引有效
>>> obj = Items('a', 'b', 'c', 'd')
>>> obj[1]
>>> 'b'
通过 mysecond
方法访问它也是如此
>>> obj.mysecond()
'b'
但由于某些原因,使用second()
方法会引发异常
>>> obj.second()
TypeError: itemgetter expected 1 arguments, got 0
什么给了?
最佳答案
obj.second
是函数 getseconditem
。一个需要参数进行操作的函数。由于您调用 obj.second
时没有任何参数,因此会引发您给出的错误。要解决它,您可以执行 obj.second(obj.items)
或以不同方式定义 second
:
class Items(object):
def __init__(self, *items):
self.items = items
def __getitem__(self, i):
return self.items[i]
def second(self):
return getseconditem(self.items)
编辑
编辑问题后,您现在的意思很清楚。我认为这里发生的事情是因为 getseconditem
不是 user-defined 函数,所以它不会在访问 obj.second
时转换为方法>。它只是一个功能。在 docs
中可以找到以下内容:
Note that the transformation from function object to (unbound or bound) method object happens each time the attribute is retrieved from the class or instance. In some cases, a fruitful optimization is to assign the attribute to a local variable and call that local variable. Also notice that this transformation only happens for user-defined functions; other callable objects (and all non-callable objects) are retrieved without transformation.
关于Python:itemgetter() 返回的函数在类中没有按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8906392/
在实际情况下可能不是安排数据的最佳方式,但它是一个很好的例子: In [16]: import operator In [17]: DF=pd.DataFrame({'Val1':[[2013, 37
有没有办法使用 itemgetter 获取一组列的补码? 例如,您可以使用 获取列表的第一个、第三个和第五个元素 from operator import itemgetter f = itemget
operator.itemgetter()函数是这样工作的: >>> import operator >>> getseconditem = operator.itemgetter(1) >>> ls
正如屏幕名称所证明的那样,我是 Python 新手。我试图对元组列表进行排序,认为列表中的 (x,y) 对并遇到了问题。我的目标是主要按 x 变量按升序对元组列表进行排序,然后进行排序 我调查了关于
我有一个字典,其中包含人名和股票值(value),我想获取元组组成股票的名称和最大值(value)。这里有一个问题:一些股票值(value)不可用并以 'NaN' 形式插入,因此,我想过滤它们。 ma
from operator import itemgetter from itertools import takewhile xs = [ ('foo',1), ('bar',1), ('baz',
我有以下字典: inventory = {'apple':(3, 133), 'banana':(9, 407), 'pear':(17, 205), 'orange':(1, 91)} 我想根据元组
我有一个要排序的元组列表。元组包含字符串: connectionsList = [('C', 'B'), ('A', 'C'), ('D', 'B'), ('C','D')] 元组中的字符串将数值存储
我注意到 operator.itemgetter 对象没有定义 __eq__,因此它们的比较默认为检查身份(is)。 当两个 itemgetter 实例的初始化参数列表比较相等时,将它们定义为相等有什
如何将 itemgetter 与列表变量而不是整数一起使用?例如: from operator import itemgetter z = ['foo', 'bar','qux','zoo'] id
这是我的词典: a = [{"id":1,"data":{"age":16,"name":a}}, {"id":3,"data":{"age":35,"name":b}}, {"i
我有一本已转换为列表的字典,因此我可以按第一项排序。字典中的键是(数字的)字符串,值是列表中维护的整数。 字典转换的列表如下所示: [('228055', 1), ('228054', 1), ('2
我最近学会了使用ìtemgetter(i)在Python中获取多个列表中的第i个元素。例如: j_column=list(map(itemgetter(j), board[i+1:])) board[
我有一个正在阅读的文件,然后创建了我想要的嵌套列表,然后按 4 元素(邮政编码)排序 jk43:23 Marfield Lane:Plainview:NY:10023 axe99:315 W. 115
我有一个用 functools.cmp_to_key 包装的比较器函数,这样我就可以在调用 sorted() 时使用它。 问题是我已经在使用 itemgetter 作为 key 。 itemgette
我正在尝试根据元素的属性在列表中选择最常见的项目。 a1 = Myclass(name='a') a2 = Myclass(name='a') b1 = Myclass(name='b') l = [
Python 2.7.5 (default, Sep 12 2013, 12:43:04) [GCC 4.4.7 20120313 (Red Hat 4.4.7-3)] on linux2 Type
我刚开始学习 Python 时遇到过这个非常简单的代码无法正确处理: import operator; b=[(5,3),(1,3),(1,2),(2,-1),(4,9)] sorted(b,key=
我很好奇是否有任何迹象表明 operator.itemgetter(0) 或 lambda x:x[0] 哪个更好用,特别是在 sorted() 作为 key 关键字参数,因为这是首先想到的用途。是否
A question was asked here on SO ,几分钟前,关于根据值对字典键进行排序。 几天前我刚刚阅读了关于 operator.itemgetter 排序方法的信息,并决定尝试一下
我是一名优秀的程序员,十分优秀!