问题描述
||
不幸的是,我必须在2.4之前的版本中使用python,所以我没有内置的“ 0”功能。我需要对列表进行排序;我发现不可能去
for aName in mylist.sort(lambda x,y:cmp(x.getName,y.getName)):
因为那样的话我会得到一个错误
TypeError: iteration over non-sequence
我要执行以下操作:
for aName in sorted(mylist,key=lambda x:x.getName):
有人可以帮我吗?非常感谢。
解决方法
您说您想做
for aName in sorted(mylist,key=lambda x:x.getName):
,但接受了一个答案却又做了其他事情...
编写可以在多个版本的Python 2.x上运行的代码很有可能。这是将sorted()
功能改造为Python 2.1至2.3的方法。它使用DSU(decorate-sort-undecorate)(又称“ Schwartzian变换”)方法...请参阅Sorting HOWTO的本节,但要阅读整个HOWTO。它非常有用。
try:
sorted
def mysorted(iterable,key,reverse=0):
return sorted(iterable,key=key,reverse=reverse)
except NameError: # doesn\'t have \"sorted\"
def mysorted(iterable,reverse=0):
temp = [(key(x),x) for x in iterable]
temp.sort()
if reverse:
return [temp[i][1] for i in xrange(len(temp) - 1,-1,-1)]
return [t[1] for t in temp]
mylist = \'tom dick harriet alfred zechariah\'.split()
mykey = lambda x: x[2:] # ignore 1st 2 characters
print mylist
print mysorted(mylist,mykey)
print mysorted(mylist,mykey,reverse=1)
使用Python 2.7.1和2.1.3运行上述脚本会产生相同的输出:
[\'tom\',\'dick\',\'harriet\',\'alfred\',\'zechariah\']
[\'zechariah\',\'tom\',\'harriet\']
[\'harriet\',\'zechariah\']
,mylist.sort(lambda x,y:cmp(x.getName,y.getName))
for aName in mylist:
...
list.sort
就地排序,没有返回值。
,def sorted(iter,**rest):
temp = list(iter)
temp.sort(**rest)
return temp
我认为应该可以。