Pthon(十一)sorted函数

需求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))

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值