python 排序输出为什么结果不一样?
发布网友
发布时间:2022-04-23 06:28
我来回答
共3个回答
懂视网
时间:2022-04-19 05:37
也就是说只有引用透明,也就是没有副作用的函数,才应该具有返回值。
x.sort(),很明显,改变了 x 的值,具有副作用,所以不应该有返回值。
2.从易读性角度来说, Guido van Rossum
在 Python-Dev 邮件列表里也解释过为什么选择将 x.sort() 的返回值定为 None. (邮件原文:[Python-Dev] sort() return value
)
3. 从性能和易用性角度来说,Python Doc 解释了为什么要这样设计(Design and History FAQ- List sort
)。
In situations where performance matters, making a copy of the list just to sort it would be wasteful. Therefore, list.sort() sorts the list in place. In order to remind you of that fact, it does not return the sorted list. This way, you won’t be fooled into accidentally overwriting a list when you need a sorted copy but also need to keep the unsorted version around.
这并不。
一门编程语言提供了一个sort函数的时候,作为使用者第一个应该问的问题是:这个函数是in-place的还是返回一个新object。Python的sort是in-place的,那么排序完成后的列表就没有返回的必要了,当然返回None是最正确的做法,有什么坑可言?
sorted函数和list的sort方法是不一样的
举个简单的例子,dog是一个对象,那dog.bark()应该返回什么?叫完了不就完了嘛,还返回啥。
但是如果有一个函数mated,那mated(dog)应该返回什么?日过的狗,mated_dog。
list.sort()是该list自身调用,list将自身(self)排序(sort)一下,自身(self)发生了改变,而排序这个动作本身是不需要返回什么的,再例如I.eat(apple),难道这个eat还需要返回一个我吗?
而sorted这个函数,是将传入的对象排序返回,这个函数没有什么自身的存在,所以不返回点什么东西,那就没意义了。
总之,这个问题属于面向对象的程序设计,不要用函数式编程的思维硬套。
PS: 以上都是我胡说的,我根本不懂什么面向对象,函数式。
因为当你需要它返回数组时,你写错了。
在你写错的时候可以提醒你,这就是返回空的作用。
让多少人义无反顾地跳坑了?呵呵没多少。
python 还有一个sorted函数
热心网友
时间:2022-04-19 02:45
列表的sort()方法是原位置修改列表, 返回None, 可以在print之前执行排序操作, 然后直接打印原列表即可
另外还有一种解决方案:
使用内置的sorted函数
sorted(iterable, key=None, reverse= False)
iterable 表示可以传入一个可迭代对象, 比如一个列表
key指定一个函数,指定函数后,sorted会将函数的返回值作为排序依据,如果不指定函数,则按可迭代对象中的元素排序, 这个指定的函数通常使用匿名函数lambda
reverse 为True时, 按降序排序, 默认False表示按升序排序
热心网友
时间:2022-04-19 04:03
因为列表的sort方法无返回值,排序是在原列表上进行的。
所以,实际上27行输出的是sort方法的返回值,当然是None,而28行输出的才是排序后的列表。且sort方法默认是按升序(从小到大)排序的,如果想要按降序排序,可以将num.sort()改成num.sort(reverse=True)。