博客
关于我
python~迭代器,生成器(2)
阅读量:538 次
发布时间:2019-03-09

本文共 667 字,大约阅读时间需要 2 分钟。

生成器与迭代器的区别

在程序编程中,生成器和迭代器是常见的概念,但二者的区别容易引起混淆。一个重要的原则是:生成器一定是迭代器,但迭代器不一定是生成器。

迭代器的定义

迭代器是能够通过next()函数获取下一个值的对象。利用isinstance()函数可以判断一个对象是否为迭代器。例如:

from collections import Iteratorisinstance((x for x in range(10)), Iterator) → Trueisinstance([], Iterator) → Falseisinstance({}, Iterator) → Falseisinstance('abc', Iterator) → Falseisinstance(100, Iterator) → False

iter()函数的作用

虽然列表(如list)、字典和字符串等数据类型属于Iterable,但它们并不是迭代器。要将它们转换为迭代器,可以使用iter()函数:

isinstance(iter([]), Iterator) → Trueisinstance(iter('abc'), Iterator) → True

总结

:valuearea>

任何可作用于for循环的对象都是Iterable;

任何可作用于next()函数的对象都是Iterator。

虽然集合数据类型如listdictstr是Iterable,但它们本身不是Iterator。通过iter()函数可以将它们转换为Iterator对象。

转载地址:http://hfaiz.baihongyu.com/

你可能感兴趣的文章
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>