1.列表生成式
# 单层循环: 生成一个列表,列表元素为[1*1,2*2...9*9]
print([i*i for i in range(1,10)])
输出结果如下:
[1, 4, 9, 16, 25, 36, 49, 64, 81]
# 多层循环:
print([ i+j for i in 'ABC' for j in 'XYZ'])
输出结果如下:
['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
# 循环+判断语句: 输出1~10中的偶数
print([i for i in range(1,11) if i%2 == 0])
输出结果: [2, 4, 6, 8, 10]
练习:找出1~10之间的所有偶数 并且返回一个列表(包含以这个偶数为半径的园的面积)
import math
print([math.pi * i ** 2 for i in range(1, 11) if i % 2 == 0])
输出结果如下:
[12.566370614359172, 50.26548245743669, 113.09733552923255, 201.06192982974676, 314.1592653589793]
练习:列表的字符串的大写改成小写,不是字符串的去掉
# isinstance(object, classinfo) 函数来判断一个对象是否是一个已知的类型
li = ['hello','World',24,24,41,7,8,False,'Apple']
print([i.lower() for i in li if isinstance(i, str)])
输出结果如下: ['hello', 'world', 'apple']
练习:找出/var/log目录中,所有以.log结尾的文件名或者目录名
import os
print([filename for filename in os.listdir('/var/log') if filename.endswith('.log')])
输出结果如下:['yum.log', 'boot.log', 'Xorg.0.log', 'Xorg.1.log', 'wpa_supplicant.log']
2.字典生成式
1.假设有20个学生,学生的分数在60~100之间,筛选出成绩在90分以上的学生
import random
student_info = {}
for i in range(20):
name = 'stu' + str(i)
score = random.randint(60, 101)
student_info[name]=score
print([v for k,v in student_info.items() if v>90])
输出结果为: [92, 92, 93, 98, 93, 93, 101, 92]
2.将相同字母的值相加
d = dict(a=1, b=2, c=3, B=8, A=11)
print({k.lower(): d.get(k.lower(), 0)+d.get(k.upper(), 0) for k in d})
输出结果:{'a': 12, 'b': 10, 'c': 3}