首页 > 其他 > 详细

列表解析、生成器表达式、匿名函数

时间:2017-04-30 09:34:58      阅读:236      评论:0      收藏:0      [点我收藏+]

1 列表解析

1.1 缺点占内存

s="hello"
l=[1,2,3,4,5]
l1=[(i,j)for i in l for j in s]
print(l1)

运行结果:
[(1, ‘h‘), (1, ‘e‘), (1, ‘l‘), (1, ‘l‘), (1, ‘o‘), 
(2, ‘h‘), (2, ‘e‘), (2, ‘l‘), (2, ‘l‘), (2, ‘o‘),
(3, ‘h‘), (3, ‘e‘),(3, ‘l‘), (3, ‘l‘), (3, ‘o‘),
(4, ‘h‘), (4, ‘e‘), (4, ‘l‘), (4, ‘l‘), (4, ‘o‘),
(5, ‘h‘), (5, ‘e‘), (5, ‘l‘), (5, ‘l‘),(5, ‘o‘)]

2 生成器表达式(声明式)

2.1 跟列表解析使用方式一样,只是把【】换成()不占内存,每次只会有一个值

#生成器表达式
# l=[]
# with open("a.txt") as f:
#     for i in f:
#         i=i.strip()
#         goods=i.split(" ")
#         res=float(goods[-1]*goods[-2])
#         l.append(res)

with open("a.txt") as f:
    g=(float(line.split()[-1])*float(line.split()[-2]) for line in f)
    print(sum(g))

 

列表解析、生成器表达式、匿名函数

原文:http://www.cnblogs.com/amiee-785563694/p/6788497.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!