m=[[1,2,3],[4,5,6],[7,8,9]] col2=[row[1] for row in m] #获取列表m的每个元素的第二个元素的值组成的列表 print(col2) print([row[1]+1 for row in m]) #获取列表m的每个元素的第二个元素+1的值组成的列表 print([row[1] for row in m if row[1]%2==0]) #获取列表m的每个元素的第二个元素且是偶数的值组成的列表 print([m[i][i] for i in [0,1,2]]) #获取m[0,0],m[1,1],m[2,2]的值组成的列表 print([c*2 for c in 'spam']) #获取spam每个字节*2后点值组成的列表
列表解析语法也可以用来创建产生所需结果的生成器
m=[[1,2,3],[4,5,6],[7,8,9]] g=(sum(row) for row in m) print(type(g)) #g是一个生成器generator,内容是m的三个元素的子元素相加的和 print(next(g)) #m[0][0]+m[0][1]+m[0][2]=6 print(next(g)) #m[1][0]+m[1][1]+m[1][2]=6 print(next(g)) #m[2][0]+m[2][1]+m[2][2]=6 print(next(g)) #超出范围,报异常
m=[[1,2,3],[4,5,6],[7,8,9]]
列表解析语法可以用来创建集合
m=[[1,2,3],[4,5,6],[7,8,9]]print({ sum(row) for row in m}) #生成一个集合,内容是m的三个元素的子元素相加的和
列表解析语法可以用来创建字典
m=[[1,2,3],[4,5,6],[7,8,9]]print({i: sum(m[i]) for i in range( 3)}) #生成一个字典{0: 6, 1: 15, 2: 24}
列表,集合,字典都可以用解析来创建
print([ord(x) for x in 'spaam']) #[115, 112, 97, 97, 109] print({ord(x) for x in 'spaam'}) #{112, 97, 115, 109} 集合会去重 print({x: ord(x) for x in 'spaam'}) #{'s': 115, 'p': 112, 'a': 97, 'm': 109} 集合键值重复执行更新操作
扩展的列表解析语法
lines=[line for line in open('e:/kangyujiao/test.txt') if line[0]=='b'] #每行第一个字符是b的返回
l=[x+y for x in 'abc' for y in 'lmn'] #嵌套循环l=['al', 'am', 'an', 'bl', 'bm', 'bn', 'cl', 'cm', 'cn']