python - 列表解析

名词解释:

  列表解析 - 根据已有列表,高效创建新列表的方式

优点:

  列表解析,比一般方法的速度,几乎快一倍

语法:

  [expression for i in data]

 

举例:

1. 简单列表解析

生成0-10的数字列表

n = [i for i in  range(0, 11)]
print(n)   # 打印:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

2. 带条件的列表解析

生成列表:[0, 2, 0, 4, 0, 6, 0, 8, 0, 10](长度为10,奇数为0,偶数不变)

n = [i+1 if i%2 == 1 else 0 for i in  range(0, 10)]   # if语句在for前面时,必须有else,不然会报错
print(n)   # 打印:[0, 2, 0, 4, 0, 6, 0, 8, 0, 10]
n = [i+1 for i in range(0,10) if i%2 == 1]  # if 在后面时,不能有else,不然会报错
print(n)   # 打印:[2, 4, 6, 8, 10]

3. 对文件的操作

列出/tmp/zhangyang中,所有以.log结尾的文件

 

普通方法
import
os file1 = [] for i in os.listdir('/tmp/zhangyang'): # os.listdir() 列出某路径下的所有文件及文件夹 if i.endswith('.log'): # 筛选出以.log结尾的 file1.append(i) print(file1) # 打印['2.log', '1.log']
列表解析方法
file2 = [i for i in os.listdir('/tmp/zhangyang') if i.endswith('.log')] print(file2) # 打印['2.log', '1.log']

4. 多重循环

实现两个列表中的元素逐一配对

普通方法
list1 = ['a', 'b', 'c'] list2 = [1, 2, 3] my_list = [] for x in list1: for y in list2: my_list.append((x, y)) print(my_list) # 打印:[('a', 1), ('a', 2), ('a', 3), ('b', 1), ('b', 2), ('b', 3), ('c', 1), ('c', 2), ('c', 3)]
列表解析方法
my_list2 = [(x, y) for x in list1 for y in list2] print(my_list2) # 打印:[('a', 1), ('a', 2), ('a', 3), ('b', 1), ('b', 2), ('b', 3), ('c', 1), ('c', 2), ('c', 3)]

 矩阵降维

list1 = [('a', 1), ('a', 2), ('a', 3), ('b', 1), ('b', 2), ('b', 3), ('c', 1), ('c', 2), ('c', 3)]

my_list = [y for x in list1 for y in x] # 注意两个for的先后顺序,高维在前
print(my_list)  # 打印:['a', 1, 'a', 2, 'a', 3, 'b', 1, 'b', 2, 'b', 3, 'c', 1, 'c', 2, 'c', 3] 

5. 字典解析

 把列表转变为字典

jj = {k: v for k, v in [(1, 201), (2, 201), (3, 205)]}
print(jj)  # 打印:{1: 201, 2: 201, 3: 205}

6. 生成9*9乘法表

print('\n'.join([''.join(['%s*%s=%-2s '%(y,x,x*y)for y in range(1,x+1)])for x in range(1,10)]))

结果如下:

 

 

 

  

posted @ 2020-08-01 13:27  小虫虫大虫虫  阅读(318)  评论(0编辑  收藏  举报