【2017-09-26】迭代器与生成器(三)

2017-09-26  本文已影响0人  小蜗牛的成长
>>> headers = ['name', 'shares', 'price','other']
>>> values = ['ACME', 100, 490.1]
>>> for name,value in zip(headers,values):
    print(name,"=",value )

name = ACME
shares = 100
price = 490.1
>>> 

上述迭代长度仅根参数最短序列长度一致,若需要与最长序列一致,可以使用 itertools.zip_longest() 函数来代替
上述例子可改写为:

>>> import itertools
>>> for name,value in itertools.zip_longest(headers,values):
    print(name,"=",value )

name = ACME
shares = 100
price = 490.1
other = None
>>> 
>>> values = ['ACME', 100, 490.1]
>>> for idx,val in enumerate(values,1):
    print(idx,val)

    
1 ACME
2 100
3 490.1
>>> for idx,val in enumerate(values):
    print(idx,val)

    
0 ACME
1 100
2 490.1
>>> data = [ (1, 2), (3, 4), (5, 6), (7, 8) ]
>>> for idx,val in enumerate(data):
    print(idx,val)

0 (1, 2)
1 (3, 4)
2 (5, 6)
3 (7, 8)
>>> 

示例2:统计文本文件单词出现的行号

# -*- coding: utf-8 -*-
from collections import defaultdict

work_sum=defaultdict(list)
with open("1.txt","r") as fp:
       lines=fp.readlines()
       for idx,val in enumerate(lines,1):
              words=[w.lower() for w in val.split()]
              for word in words:
                     work_sum[word].append(idx)

print(work_sum)
#过滤到#开头的
with open("1.txt","r") as fp:
       for line in dropwhile(lambda line :line.startswith('#'), fp):
              print(line)

值得注意的是,dropwhile() 函数仅仅是跳过满足条件的开始行

上一篇 下一篇

猜你喜欢

热点阅读