python 列表解析

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']




猜你喜欢

转载自blog.csdn.net/weixin_37016700/article/details/78311397