本文共 3104 字,大约阅读时间需要 10 分钟。
需求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)) 小写(所以大写在前,小写在后)print(sorted(list6))#> 小写list6=['dfs','fds','tda','eds']print(list6)#>
(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个元素),要求调整元素的顺序:把奇数放在前面 偶数放在后面"""# 方式1list1=[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))
转载地址:http://dizwz.baihongyu.com/