Python -- 函数之推导式
2020-12-13 03:04
标签:print 迭代器协议 取值 class upper name 迭代器 generator 去重 生成器表达式 生成器表达式和列表推导式的语法上一模一样,只是把 [] 换成 () 就行了。 Python -- 函数之推导式 标签:print 迭代器协议 取值 class upper name 迭代器 generator 去重 原文地址:https://www.cnblogs.com/Agoni-7/p/11067009.html5.12 推导式
l = []
for i in range(1,11):
l.append(i)
print(l)
# 用列表推导式 (一行搞定)
l = [i for i in range(1,11)]
print(l)
# 循环模式
1. 将10以内所有整数的平方写入列表。
l = [i**2 for i in range(1,11)]
print(l)
2. 100以内所有的偶数写入列表.
l = [i for i in range(2,101,2)]
3. 从python1期到python100期写入列表lst
l = [f'python{i}期' for i in range(1,101)]
print(l)
# 筛选模式
1. 将这个列表中大于3的元素留下来。
l1 = [4, 3, 2, 6, 5, 5, 7, 8]
print([i for i in l1 if i > 3])
2. 三十以内可以被三整除的数。
l = [i for i in range(30) if i % 3 == 0]
print(l)
3. 过滤掉长度小于3的字符串列表,并将剩下的转换成大写字母
l = ['wusir', 'laonanhai', 'aa', 'b', 'taibai']
print([i.upper() for i in l if len(i) > 3])
4. 找到嵌套列表中名字含有两个‘e’的所有名字(有难度)
names = [['Tom', 'Billy', 'Jefferson', 'Andrew', 'Wesley', 'Steven', 'Joe'],['Alice', 'Jill', 'Ana', 'Wendy', 'Jennifer', 'Sherry', 'Eva']]
print([n for i in names for n in i if n.count('e') >= 2])
# 注意遍历顺序是实现的关键
1. 比如将十以内所有数的平方放到一个生成器表达式中
gen = (i**2 for i in range(10))
print(gen)
# 结果是内存地址
# 字典推导式
lst1 = ['jay','jj','meet']
lst2 = ['周杰伦','林俊杰','郭宝元']
dic = {lst1[i]:lst2[i] for i in range(len(lst1))}
print(dic)
# 集合推导式
集合推导式可以帮我们直接生成一个集合,集合的特点;无序,不重复 所以集合推导式自带去重功能
lst = [1,2,3,-1,-3,-7,9]
s = {abs(i) for i in lst}
print(s)
上一篇:Java中并发和并行的概念