python高级内置函数和各种推导式的介绍:一行搞定的代码

时间:2024-01-14 20:55:26

一、知识要点

all 都为真
any 有真的
min 最小的
max 最大的
sum 求和
reversed 反转
sorted 排序
zip 对应合并
[] 列表推倒式
() 生成器
{} 字典推倒式
set 去重
if三元操作符 xx if x else y
ennmerate 枚举,带索引

二、 代码

"1. all"
# 参数为一个可迭代的对象(Iterable)
m =[1, 2, 3, 4, ''] # 当然不是这样简答的使用
print(all(m)) def a1():
# 完成一系列操作
return False def a2():
# 完成一系列操作
return True def a3():
# 完成一系列操作
return True if all([not a1(),a2(),a3()]):
# 前一个为假,最后为真运行这里
print('are u ok') "2. any"
# 只要有真的就运行,参数也是一个可迭代的对象
print(any([0,'',' '])) # True "3. min,max"
print(min([10,2,3,4,5]))
print(max([10,2,3,4,5])) "4. sum"
# 两个参数:第一个参数可迭代的对象数组,第二个参数为前面累加和 再加上这个参数,当第一个参数为空,直接返回第二个参数
print(sum(range(100),10)) "5. reversed"
# 对一个序列进行反转,返回一个可迭代的对象
li_m = [123,32,234,2123,43,12,53] for i in reversed(li_m):
print(i) [i for i in reversed(li_m)] # 使用列表推倒式一行搞定 "6. sorted排序"
# 默认的列表排序
li_m = [123,32,234,2123,43,12,53]
li_m.sort() # 有两个参数 key 与 revered
print(li_m) # sorted 是返回一个新列表
new_li = sorted([1,34,123,111,23])
print(new_li)
new_li = sorted([-1,-3,-9,2,4], key=abs) # 根据绝对值进行排序,也可以使用lambda排序
print(new_li) "7. zip"
# 拉链,合并两个序列(一一对应)
x = [1,2,3,4,5]
y = ['a', 'b', 'c']
print(list(zip(x, y)))
print(dict(zip(x,y))) "8. 推倒式"
# 列表推倒-->也可以使用map推到,但是比较麻烦
print([x for x in range(10)])
print([x*100 for x in range(10)])
print([x for _ in rang(len(list))]) # 当某个参数使用不到的时候,直接使用_代表,避免浪费变量 # 生成器表达式----> 优先使用这个,节约内存
print((x**3 for x in range(8)))
for i in (x**3 for x in range(8)):
print(i) # 字典推导式
# 把下面的v转换为大写
info = {'louhui':'hz','laoniu':'hengxi','caoyu':'dongwu'} # 1,常规做法
info_new = {}
for k,v in info.items():
info_new[k] = v.upper()
print(info_new) # 2. 字典推到
a = {k:v.upper() for k,v in info.items()}
print(a) "9. 去重"
s = [1,2,2,2,33,43,3,3,3,]
ss = set(s)
print(ss) "10. 三元操作符"
# 前面是返回值,如何为真,则用前面,为假则为后面的值
True if s == 'a' else False
# 一般用在函数的返回值
def func(s):
# many
return True if s =='a' else False "11. 枚举"
# 就是给列表加上下表
menu = ['add', 'del', 'modfiy', 'find']
for num, m in enumerate(menu):
print(num+1,m)