5.12 推导式
l = []
for i in range(1,11):
l.append(i)
print(l)
# 用列表推导式 (一行搞定)
l = [i for i in range(1,11)]
print(l)
列表推导式可分为两种模式:
循环模式: [变量(加工的变量) for 变量 in iterable(可迭代对象)]
筛选模式: [变量(加工的变量) for 变量 in iterable(可迭代对象) if 条件]
# 循环模式
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)
# 结果是内存地址 at 0x000002BFC2431C50>
# 取值
for n in gen:
print(n)
2. 生成器表达式也可进行筛选
# 100 以内能被3整除的数
gen = (i for i in range(100) if i % 3 == 0)
for num in gen:
print(num)
生成器表达式和列表推导式的区别:
离别推导式比较耗内存,所有的数据一次性加载到内存,而生成器表达式遵循迭代器协议,逐个产生元素
得到的值不一样,列表推导式得到的是一个列表,生成器表达式获取的是一个生成器(内存地址)
列表推导式一目了然,生成器表达式只是一个内存地址
其他相关的推导式
# 字典推导式
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)