python—列表生成式

时间:2024-01-17 14:01:56
 #原始写法
l=[]
for i in range(1,11):
l.append(str(i).zfill(2))
print(l)
#结果:['01', '02', '03', '04', '05', '06', '07', '08', '09', '10']

列表生成式,只能用在列表中

先写循环,再把循环里的i拿出来,可以做一些简单的操作(补零、转换为字符串等)

 # 列表生成式
l2=[str(i).zfill(2) for i in range(1,11)]
print(l2) #结果:['01', '02', '03', '04', '05', '06', '07', '08', '09', '10']

小练习:(创建一个文件)

 import os
# 创建文件
res=[open('%s.txt'%i,'w')for i in range(10)]
# 创建文件夹
# res=[os.mkdir(str(i))for i in range(10)]

小练习:(列表生成式,加判断)

 # 加判断写法(列表生成式只可以加判断)
res=[os.mkdir(str(i))for i in range(10) if i%2!=0] #遇到偶数创建
res=[os.mkdir(str(i))for i in range(10) if i>0] #if可以加可以不加

小练习:(生成100以内的奇数)

 l = [i for i in range(1,51,2)]#外面是[]就是一个list
print(l)
#结果:[1, 3, 5, 7, 9, 11, 13, 15, 17, 19, 21, 23, 25, 27, 29, 31, 33, 35, 37, 39, 41, 43, 45, 47, 49]

生成器

 #列表生成式
l = [i for i in range(1,11,2)]#外面是[]就是一个list
print(l)
#结果:[1, 3, 5, 7, 9]
#以空间换时间,内存占用大,但是不用再计算省cpu
#list它是把所有的元素都放在内存里面的,这里就会申请5块内存空间 #生成器()
l=(i for i in range(1,11,2))#外面是()的话,就是生成器
print(l)
10 # 结果:<generator object <genexpr> at 0x000000000266A4C0> for i in l:
print(i)
# 结果:
#
#
#
#
#
#generator生成器比list要节省内存,它是每次循环的时候,会根据规则计算一个元素,放到内存里面
#generator性能比list好一些,只申请一块内存空间,每次调用再去根据规则算

三元表达式

 #初级写法
sex=0
if sex==0:
sex='女'
else:
sex='男'
print(sex) # 三元表达式
# 高级写法
sex=0
sex= '女' if sex==0 else '男' #(满足条件取前面的 值,条件不满足取后面的 值)
print(sex)

小练习二

 a = 5
b = 6
# if a > b:
# c = a
# else:
# c = b
c = a if a > b else b #如果a大于b的话,a = c,否则 c =b
print(c)