Python——迭代器和解析

迭代器

Python迭代工具包括for循环、列表解析、in成员关系测试以及map内置函数

可迭代对象

可迭代对象就是序列观念的通用化:如果对象是实际保存的序列,或者可以在迭代工具环境中一次产生一个结果的对象。就看做是可迭代的。

文件迭代器

Python在读取文件时的readline方法后,就会前进到下一列。到达文件末尾时,就会返回空字符串

next 方法

现在有了名为next的方法,差不多有相同的效果:每次调用时,就会返回文件中的下一行。当到达文件末尾时,next会引发内置的stopIteration异常,并不返回空字符串。读取文件时所有的迭代器内部工作起来都是在每次迭代中调用next并捕捉StopIteration异常来确定离开

  • 读取文本的最佳方式
>>> for line in open('/tmp/test.txt','r'):
...     print(line.upper())

在这种方式是最简单的写法,运行最快
从内存使用情况来说也是最好的
而对于普通的调用文件的readlines方法,会将文件内容加载到内存。在内存中生成一个字符串的列表

手动迭代 iter和next

next

  • 为了支持手动迭代代码,Python3.0还提供了一个内置函数next,next会自动调用next方法。给定一个可迭代对象X调用next(X)等同于next()
>>> f = open('/tmp/test.txt','r')
>>> next(f)
'adsads\n'
>>> next(f)
'ssq\n'
>>> next(f)
'q\n'

iter

当for循环开始时,会通过它传给iter内置函数,以便从可迭代对象中获得一个迭代器。返回的对象含有需要的next方法

>>> L = [1,2,3]
>>> i = iter(L)
>>> i.next()
1
>>> i.next()#2.X
2
>>> i.next()
3
>>> next(i)
1

列表解析

>>> L = [1,2,3,4,5]
>>> X = [I for I in L]
>>> X
[1, 2, 3, 4, 5]
  • 列表解析并不完全和for循环语句版本相同。列表解析表达式产生一个新的列表对象。
L = [x+10 for in L]
  • 列表解析写在一个方括号中,表达式使用我们所组成的一个循环变量(x+10),作为for循环头部的部分
  • 列表解析比手动的for循环语句运行更快,执行速度往往要快一倍。迭代在解释器内部是以C语言的速度执行的

文件上使用列表解析

>>> lines = [line.rstrip() for line in open('/tmp/test.txt','r')]
>>> lines
['adsads', 'ssq', 'q', '', 'qqweweq', 'eqweq', 'zsdsdsd', 'ASDSDWDA', 'sdadASADSDA', '']

列表解析语法的扩展和高级应用

在想要将文件以a字母开头的行打印
>>> lines = [line.rstrip() for line in open('/tmp/test.txt','r') if line[0]=='a']
>>> lines
['adsads']

列表解析嵌套循环

>>> List = [str(x)+y for x in A for y in B]
>>> List
['1a', '1b', '1c', '1d', '1e', '2a', '2b', '2c', '2d', '2e', '3a', '3b', '3c', '3d', '3e', '4a', '4b', '4c', '4d', '4e', '5a', '5b', '5c', '5d', '5e']

字典视图迭代器

在Python3.0中,字典Keys values和item方法返回可迭代的视图对象,一次产生一个结果项

>>> D = dict(a=1,b=2,c=3)
>>> D
{'a': 1, 'b': 2, 'c': 3}
>>> k = D.keys()
>>> K
>>> k = D.keys()
>>> K
>>> I = iter(K)
>>> I = iter(D.keys())
>>> I

>>> next(I)
'a'
>>> next(I)
'b'
>>> next(I)
'c'
>>> next(I)
  • 和所有的迭代器一样,我们总可以通过把一个Python3.0字典视图传递到List内置函数中,构成一个真正的列表

你可能感兴趣的:(Python——迭代器和解析)