列表生成式
相较于之前使用for循环生成列表的方式,这种写法更专业
可能是因为这更加地符合python编程规范与思维
而之前的使用for循环生成的方式则更类似于以前的c语言编程写法
# 生成一个列表,列表元素分别为[1**1 2**2 3**3...9**9]
import math
li = []
for i in range(1, 10):
li.append(i ** i)
print(li)
print([i ** i for i in range(1, 10)])
# 在上面的基础上,筛选出偶数项
print([i ** i for i in range(1, 10) if i % 2 == 0])
# S1='ABC' S2='123' A1 A2 A3.. 输出两字符串元素之间的所有组合
print([i + j for i in 'ABC' for j in '123'])
# 找出1~10之间的所有偶数.并且返回一个列表(包含以这个偶数为半径的园的面积)
# print(math.pi)
# for r in range(2, 11, 2):
# square = math.pi * r * r
# li.append(square)
# print(li)
print([math.pi * r * r for r in range(2, 11, 2)])
# 结合函数,使用列表生成式
def square(r):
res = math.pi * r * r
return res
print([square(i) for i in range(2,11,2)])
对于列表生成式的执行,我的理解是:
print([i+j for i in "ABC" for j in "123" ])
生成式中的追加元素为i+j,i和j是通过两个循环语句生成的,两个循环语句的相对位置,决定了i,j生成的先后顺序
for i in "ABC": #这个语句即上面列表生成式最左侧的列表追加元素的外部循环条件
for j in "123": #这个语句即上一循环语句内部的循环条件
listname.append(i+j) #这里的i+j即上面列表生成式最左侧的参数
print(listname)
简单应用示例:
生成一个列表,存储指定范围内的素数
def isprime(num):
for i in range(2,num):
if num % i == 0:
return False
else:
return True
primeli = [i for i in range(2,100) if isprime(i)] # 使用函数和列表生成式生成指定列表
字典生成式
利用上面的列表生成式,我们可以快速地生成指定元素组成的列表
而同样地,使用列表生成式,我们也可以将其转换为元组,集合,从而达到快速生成
但是这却无法生成字典类型,因此还有字典生成式
list = {num:score for score in range(100) if score <50 for num in (1,2,43,45,5)}
这个语句生成的字典{1: 49, 2: 49, 43: 49, 45: 49, 5: 49}。并不是两层循环嵌套失败了,而是相同的key值的元素,更新了原来的值
可见这种循环方式并不适合用于字典生成键
(1)
import random
stuInfo = {}
# 生成一个随机值的字典,在该字典的数据的基础上,使用字典生成式生成字典
for i in range(20):
name = 'westos' + str(i)
score = random.randint(60, 100)
stuInfo[name] = score
print(stuInfo)
# highscore ={}
# for name,score in stuInfo.items():
# if score > 90:
# highscore[name] = score
# print(highscore)
print({name: score for name, score in stuInfo.items() if score > 90})
# 筛选出成绩90以上的数据对
(2)
d = dict(a=1,b=2)
print(d)
new_d = {}
for i in d:
new_d[i.upper()] = d[i]
print(new_d)
print({k.upper():v for k,v in d.items()})
# 将字典的索引都变为大写,输出字典
(3)
d = dict(a=1,b=2,c=3,B=8,A=10)
# new_d = {}
# for k,v in d.items():
# low_k = k.lower()
# if low_k not in new_d:
# new_d[low_k] = v
# else:
# new_d[low_k] += v
#
# print(new_d)
print({k.lower():d.get(k.upper(),0)+d.get(k.lower(),0)for k in d})
# 将同一字母的大小写的值合并为一对键值对