概述
需求1:快速生成验证码(内推码)
import random
# 了解该模块的方法!
import string
# 数字和字母(大小写)-->构成列表(字符串)--->截取若干数字
code_str = string.ascii_letters + string.digits
# code_str1 = string.ascii_lowercase
# code_str2 = string.ascii_uppercase
# 默认参数
def gen_code(len=4):
# code = ''
# for i in range(len):
# new_s = random.choice(code_str)
# code += new_s
#
# return code
# join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串
return ''.join(random.sample(code_str, len))
# 产生若干个验证码-->列表生成式!
print([gen_code() for i in range(10)])
二、高阶函数sorted函数
(1)sort排序回顾
list1 = [1, 6, 5, 8, 3]
tulpe1 = (1, 6, 5, 8, 3)
# 强调:只有list列表有此方法(元组没有此方法),是原址排序!!!
list1.sort()
print(list1)
(2)sorted高阶排序
# 注意:辩证sort和sorted的区别!
list1 = [1, 5, 3, 7, 10, 9, 18]
list2 = sorted(list1)
print(list1)
print('-----------------')
print(list2)
print(list1 is list2) False
# 说明:sorted开辟了一个新的地址空间--->对原来数据的拷贝,新的地址保存!
2.1)默认排序
说明:排序的对象是可迭代的对象即可,相比sort更宽容!
字典排序:默认会按照dict的key值进行排序,最后返回的结果是一个对key值排序好的list!
排序的控制方式:基于key函数(可以做文章)、基于cmp函数(了解)、基于reverse函数(默认是False,降序排序)!
##########key函数的说明###########
(1)内置函数进行排序
从python2.4开始,list.sort()和sorted()函数增加了key参数来指定一个函数
特点:此函数将在每个元素比较前被调用,key参数的值为一个函数,此函数只有一个参数且返回一个值用来进行比较!
通俗的讲:排序并不由源元素而决定,而是根据key指定调用函数的结果决定!
练习1
# 需求1:正负数绝对值排序!
list4=[1,-5,3,-10,9,8,-12,6,13]
list5= sorted(list4,key=abs) #python内置的abs函数
print(list5)
# [1, 3, -5, 6, 8, 9, -10, -12, 13]
练习2
# 需求:字符串的比较
# 说明:Ascii-->大写<小写
list6=['dfs','Fds','tda','Eds']
print(list6)
# 默认以Ascii比较--->大写<小写(所以大写在前,小写在后)
print(sorted(list6))
# 需求:转换为小写后进行比较
print(sorted(list6,key=str.lower))
# 需求:转化为大写后进行比较
print(sorted(list6,key=str.upper))
# 需求:说明的是-->recersed是将排序后的结果进行反转!
print(sorted(list6,key=str.upper,reversed=True))
(2)自定义函数进行排序
需求1
"""
1.假设我们用一组tuple表示学生名字和成绩,L =[('Bob', 75), ('Adam', 92), ('Bart',66),('Lisa', 88)],
1-->按名字进行排序(不歧视)
2-->按成绩进行排序
"""
L =[('Bob', 75), ('Adam', 92), ('Bart', 66),('Lisa', 88)]
print(sorted(L,key=lambda x:x[0]))
# 按照成绩进行排序
print(sorted(L,key=lambda x:x[1]))
需求2
my_dict = {"a":"2", "c":"5", "b":"1"}
result = sorted(my_dict)
print result
#默认对dict排序,不指定key参数,会默认对dict的key值进行比较排序!
#result输出: ['a', 'b', 'c']
result2 = sorted(my_dict, key=lambda x:my_dict[x])
print result2
#指定key参数,根据dict的value排序
#result2输出:['b', 'a', 'c']
#注意:输出的还是key!!!
需求3
"""
题目需求:
(1)给定一个整形数组,将数组中所有的0移动到末尾, 非0项保持不变;
(2)在原始数组上进行移动操作, 勿创建新的数组;
# 输入:
第一行是数组长度, 后续每一行是数组的一条记录;
4
0
7
0
2
# 输出:
调整后数组的内容;
7
2
0
0
"""
def move_zore(item):
if item == 0:
return 2
else:
return 1
# 调用函数!
for i in sorted(li,key=move_zore):
print(i)
需求4:
"""
有一个整数列表(10个元素),要求调整元素的顺序:把奇数放在前面 偶数放在后面
"""
# 方式1
list1=[1,2,19,18,16,14,13,17,22]
print([i for i in sorted(list1,key=lambda j:(j+1)%2)])
# 说明:相当于根据return (j+1)%2结果-->[0,1]来映射进行排序!
# 方式2 -->含义大概就是偶数是2,奇数是1!
#print(sorted(list1,key=lambda x:2 if x%2 == 0 else 1))
# if x%2 ==0:
# return 2
# else:
# return 1
需求5:
info = [
# 商品名称 商品数量 商品价格
('apple1',200,32),
('apple2', 40, 12),
('apple3', 1000, 23),
('apple1', 40, 2),
('apple1', 40, 5)
]
# 按照商品数量进行排序
def sorted_by_count(x):
return x[1]
# 按照商品价格进行排序
def sorted_by_price(x):
return x[2]
# 先按照商品数量进行小-大的排序,如果商品数量一样!!!-->掌握!!!
# 则按照商品价格由小-大进行排序
def sorted_by_count_price(x):
return x[1],x[2]
print(sorted(info,key=sorted_by_count))
print(sorted(info,key=sorted_by_price))
print(sorted(info,key=sorted_by_count_price))
最后
以上就是彩色老虎为你收集整理的Pthon(十一)sorted函数的全部内容,希望文章能够帮你解决Pthon(十一)sorted函数所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复