python迭代器生成器(二)

python学习网 2017-07-03 20:37:03

其他内置类型迭代器

除了文件以及列表这样的实际的序列外,其他类型也有适合的迭代器。

遍历字典的经典方法是明确的获取其键的列表。

在最近的python版本中,字典有一个迭代器,在迭代环境中,会自动一次返回一个键

列表解析:

L = [1,2,3,4,5]

L = [i + 10 for i in L]

也可以用for循环去处理:例如

Z = []

for i in range(5)

  z.append(i)

实际上,这和列表解析所做的事情是相同的。然而,列表解析编写起来更精简,比手动的for循环语句运行快1倍(大约),因为它们的迭代在解释器内部是用c语言的速度执行,试用于较大的数据集合,个人认为尽量使用列表解析。

在文件上使用列表解析

换行符很讨厌,还有就是一些双倍的空白等等。

所以我们可以考虑使用列表解析。例如:假设变量lines像前面交互模式中的一样,如下的代码通过对列表中的每一行运行字符串rstrip方法,来移除右端的空白(line[:-1]分片也有效,但是,当我们能够确保所有的行都是正确的是后,它才有效。)

当然了,列表解析这种方法也可以用在文件上,比如说打开一个文件,正常的情况下,他会出现一些换行符,用上述放发可以解决这个问题

扩展的列表解析语法

作为一个特别有用的扩展,表达式中镶嵌的for循环可以有一个相关的if子句,来过滤那些测试不为真的结果。

例如:假设我们想要重复前面小节的文件扫描示例,我们需要收集以字母s开头的那些行。向表达式中添加一条if过滤子句来实现。

可以看到将1.txt中的文件以s开头的文件过滤出来了。

 我们也可以用for循环的方式,但是运行结果就慢了很多。例如:

今天写到这里,哥们来了,去接他。

 

阅读(884) 评论(0)