十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
我只写一个函数:\x0d\x0a def littleFunc():\x0d\x0a data =[] #初始化列表\x0d\x0a for i in range(9):#一个for循环\x0d\x0a num = int(raw_input("input a number please: "))#控制输入转为int\x0d\x0a data.append(num)#放入列表\x0d\x0a data.sort()#排序\x0d\x0a print data#输出\x0d\x0a\x0d\x0apython的程序扩展名是.py\x0d\x0a程序执行结果:\x0d\x0a littleFunc()\x0d\x0ainput a number please: 1\x0d\x0ainput a number please: 3\x0d\x0ainput a number please: 5\x0d\x0ainput a number please: 7\x0d\x0ainput a number please: 8\x0d\x0ainput a number please: 4\x0d\x0ainput a number please: 9\x0d\x0ainput a number please: 6\x0d\x0ainput a number please: 2\x0d\x0a[1, 2, 3, 4, 5, 6, 7, 8, 9]
创新互联:2013年至今为各行业开拓出企业自己的“网站建设”服务,为上千家公司企业提供了专业的成都网站制作、网站建设、外贸网站建设、网页设计和网站推广服务, 定制开发由设计师亲自精心设计,设计的效果完全按照客户的要求,并适当的提出合理的建议,拥有的视觉效果,策划师分析客户的同行竞争对手,根据客户的实际情况给出合理的网站构架,制作客户同行业具有领先地位的。
python内置关于排序的工具主要有两个一个是列表自带的 sort() 方法,另外一个是 sorted() 函数。Python 列表内置方法可以直接修改列表。而 sorted() 内置函数从一个可迭代对象(列表,元组等都可以)构建一个新的排序列表。其函数原型分别如下:
对列表进行默认排序
从函数原型来看,可以看到两者都具有两个可选参数,它们都必须指定为关键字参数。
key 指定带有单个参数的函数,用于从 iterable 的每个元素中提取用于比较的键 (例如 key=str.lower)。默认值为 None (直接比较元素)。 key 形参的值应该是个函数(或其他可调用对象),它接受一个参数并返回一个用于排序的键。
假设有其他类型的变量,比如一个自定义的类或者列表中又是一个列表。以官网例子为例有这样一个列表,其元素为元组,
可以用以下方式按照年龄排序
类似的有自定义类
可以用如下方式进行排序
也可以显示定义一个函数,且只有一个参数,返回用于排序的键,比如
总之就是定义一个函数返回一个用于排序的键,可以用lambda函数或者 def 定义都可以。
上面实现的简单函数实际就是实现了返回一个有序结构的第 n 的元素,或者某个类中的某个属性,因此 Python 提供了便利功能,使访问器功能更容易,更快捷。operator 模块有 itemgetter() 、 attrgetter() 函数。分别完成返回第 n 个元素,某个属性功能。上面的排序可以用如下方式进行实现
在python2中,sort有一个 cmp 参数,即用一个函数来自定义比较,在python3中这种方式被取消。为了继承类似的用法,在 Python 3.2 中, functools.cmp_to_key() 函数被添加到标准库中的 functools 模块中。
这种作用先定义如何比较两个变量,以上面的学生列表按照年龄排序为例
这种做法自定义比较函数接收两个形参,返回比较结果(bool),而新式方法接受一个参数,返回的是比较的键。
假设有字典 d = {'b':2, 'a':1,'c':8,'d':4} ,则可以通过以下方式对字典按照键和值进行排序
Python列表具有内置的 list.sort()方法,可以在原地修改列表。 还有一个 sorted()内置的函数从迭代构建一个新的排序列表。在本文中,我们将探讨使用Python排序数据的各种技术。
请注意,sort()原始数据被破坏,sorted()没有对原始数据进行操作,而是新建了一个新数据。
一、基本的排序
最基本的排序很简单。只要使用sorted()函数即可返回一个 新的排序的列表
sorted([5, 2, 3, 1, 4])
[1, 2, 3, 4, 5]
咱们也可以使用 list.sort()方法。该方法是对列表list进行的原地操作(原数据被修改,已经不是原来的本来面目)。一般情况下,不如使用 sorted()方便,但是如果你不需要原列表list,使用 sort()会更具效率。
a = [5, 2, 3, 1, 4]
a.sort()
a #a发生改变
[1, 2, 3, 4, 5]
另一个不同点, list.sort()方法只能应用于列表对象数据。而 sorted()却可以对任何可迭代对象进行排序。也就是说sorted()更具有普遍使用性。这里大灯建议初学者使用sorted()。
二、Key参数函数
list.sort()和 sorted()都有key参数,可以指定函数来对元素进行排序。
例如,这里我们使用一个字符串(字符串也是可迭代对象)
sorted("This is a test string from Andrew".split(), key=str.lower)
简单排序的话,直接使用 list.sort() 就可以了,直接在原列表上进行排序。
非要写成函数的形式的话,代码如下
def ABC(nums_l):
nums_l.sort()
return nums_l
l = [1,2,5,3,4]
# 其实,使用 l.sort() 之后,就对l进行了排序,然后输出l就可以了
print l
print ABC(l)
这样,输出为
================================ RESTART ================================
[1, 2, 5, 3, 4]
[1, 2, 3, 4, 5]
这么基础的东西,不会的话,自己看书去。
def ABC(nums_l):
return sorted(nums_l)
def main():
nums_l = []
while True:
try:
n = int(raw_input('input num : ').strip())
nums_l.append(n)
except:
break
print '', ABC(nums_l)
if __name__ == '__main__':
main()