可迭代对象 python_列表是可迭代对象吗

可迭代对象 python_列表是可迭代对象吗引出问题:​如下面所示,存在一个类,并且产生了一个对象,现在想用for循环实现对象的迭代,结果报错了点击(此处)折叠或打开– coding: utf-8 –“””演示一个类是不可以迭代的结果存在报错信息 说明 A对象不是一个可以迭代的对象for i in A:TypeError: ‘Students’ object is not iterable“””class Students():def init(self):self.names = list()def add(self,

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

引出问题:
​如下面所示,存在一个类,并且产生了一个对象,现在想用for循环实现对象的迭代,结果报错了

# -*- coding: utf-8 -*-

""" 演示一个类是不可以迭代的 结果存在报错信息 说明 A对象不是一个可以迭代的对象 for i in A: TypeError: 'Students' object is not iterable """

class Students():
    def __init__(self):
        self.names = list()

    def add(self, name):
        self.names.append(name)

    def show(self):
        print(self.names)




if __name__ == "__main__":
    A = Students()
    A.add("Bob")
    A.add("Tom")
    A.add("Joe")
    A.add("Coe")

    for i in A:
        print(i)

    A.show()在这里插入代码片

错误原因:

在这    for i in A:
TypeError: 'Students' object is not iterable

Process finished with exit code 1
里插入代码片

​说明对象是不可以进行迭代的,那么如何实现对象的可以迭代呢
​迭代的思路逻辑

# -*- coding: utf-8 -*-
from time import sleep
""" 如下为迭代的学习思路梳理: 后面是具体的代码实现,没有把每一个步骤都进行截图和代码分享,望谅解 (1)一个类中加入__iter__f (self) 方法后变成可迭代的 并返回如下的错误,说明是类型不正确,但是已经能够发生迭代了 for i in A: TypeError: iter() returned non-iterator of type 'NoneType' (2)在此基础上增加一个新的类 class Stuends_iter(): 并同时含有__iter__()和__next__()方法 (3)在class Students():的__iter__()方法中返回一个对象 结果为 None ,并且 None是无限的循环下去,说明已经变成了可以进行迭代的,只是返回值不正确而已 (4)在(3)的基础上加上一个正确的返回值,做如下的修改 def __next__(self): return "zhangsan" 得到的结果为不是None,而是变成了zhangsan ,说明迭代的基础已经能够实现了,但是仍是无限循环的, (5)需要停止循环的话,就需要确定长度,如何确定长度呢? 采用类之间的传参 def __iter__(self): return Stuends_iter(self) def __next__(self): # len_name = len(self.obj.nam) return self.obj.names[0] 传参的结果如下,已经能够成功打印列表中的第一个值 (6) 获取所有传递的列表的长度 len_name = len(self.obj.names) #获得了长度就可以用循环遍历了 (7)完成循环遍历,并且判断长度,存在问题,遍历结束后,仍没有退出 def __next__(self): all_len = len(self.obj.names) if self.nums < all_len: ret = self.obj.names[self.nums] self.nums += 1 return ret (8)需要想办法,让循环结束 解决方法:加else抛出异常情况 def __next__(self): all_len = len(self.obj.names) if self.nums < all_len: ret = self.obj.names[self.nums] self.nums += 1 return ret else: raise StopIteration (9)通过以上办法就实现了对象的迭代 """

class Students():
    def __init__(self):
        self.names = list()

    def add(self, name):
        self.names.append(name)

    def show(self):
        print(self.names)

    def get_lst(self):
        return len(self.names)

    def __iter__(self):
        return Stuends_iter(self)


class Stuends_iter():

    def __init__(self, obj):
        self.obj = obj
        self.nums = 0

    def __iter__(self):
        pass

    def __next__(self):
        all_len = len(self.obj.names)
        if self.nums < all_len:
            ret = self.obj.names[self.nums]
            self.nums += 1
            return ret
        else:
            raise StopIteration




if __name__ == "__main__":
    A = Students()
    A.add("Bob")
    A.add("Tom")
    A.add("Joe")
    A.add("Coe")

    A.add("Bob2")
    A.add("Tom2")
    A.add("Joe2")
    A.add("Coe2")

    for i in A:
        print(i)这里插入代码片

具体的每一个步骤都写在了上面,通过2个类的方法,实现了对象的可以迭代性
​得到的结果:

在Bob
Tom
Joe
Coe
Bob2
Tom2
Joe2
Coe2

Process finished with exit code 0这里插入代码片

​改进逻辑
能不能用一个类就实现迭代呢,答案是可以的
请继续往下看:

# -*- coding: utf-8 -*-
from time import sleep
""" 如下为迭代的学习思路梳理: (1)一个类中加入__iter__f (self) 方法后变成可迭代的 并返回如下的错误,说明是类型不正确,但是已经能够发生迭代了 for i in A: TypeError: iter() returned non-iterator of type 'NoneType' (2)在此基础上增加一个新的类 class Stuends_iter(): 并同时含有__iter__()h和__next__()方法 (3)在class Students():的__iter__()方法中返回一个对象 结果为 None ,并且 None是无限的循环下去,说明已经变成了可以进行迭代的,只是返回值不正确而已 (4)在(3)的基础上加上一个正确的返回值,做如下的修改 def __next__(self): return "zhangsan" 得到的结果为不是None,而是变成了zhangsan ,说明迭代的基础已经能够实现了,但是仍是无限循环的, (5)需要停止循环的话,就需要确定长度,如何确定长度呢? 采用类之间的传参 def __iter__(self): return Stuends_iter(self) def __next__(self): # len_name = len(self.obj.nam) return self.obj.names[0] 传参的结果如下,已经能够成功打印列表中的第一个值 (6) 获取所有传递的列表的长度 len_name = len(self.obj.names) #获得了长度就可以用循环遍历了 (7)完成循环遍历,并且判断长度,存在问题,遍历结束后,仍没有退出 def __next__(self): all_len = len(self.obj.names) if self.nums < all_len: ret = self.obj.names[self.nums] self.nums += 1 return ret (8)需要想办法,让循环结束 解决方法:加else抛出异常情况 def __next__(self): all_len = len(self.obj.names) if self.nums < all_len: ret = self.obj.names[self.nums] self.nums += 1 return ret else: raise StopIteration (9)通过以上办法就实现了对象的迭代 """

class Students():
    def __init__(self):
        self.names = list()
        self.len = 0

    def add(self, name):
        self.names.append(name)

    def show(self):
        print(self.names)

    def get_lst(self):
        return len(self.names)

    def __iter__(self):  # 具有本方法的对象是可迭代的
        # return Stuends_iter(self)
        return self

    def __next__(self): # 具有本方法的对象是可迭代的,加上__next__()的方法才是迭代器
        if self.len < len(self.names):
            ret = self.names[self.len]
            self.len += 1
            return ret
        else:
            raise StopIteration


# class Stuends_iter():
#
# def __init__(self, obj):
# self.obj = obj
# self.nums = 0
#
# def __iter__(self):
# pass
#
# def __next__(self):
# all_len = len(self.obj.names)
# if self.nums < all_len:
# ret = self.obj.names[self.nums]
# self.nums += 1
# return ret
# else:
# raise StopIteration




if __name__ == "__main__":
    A = Students()
    A.add("Bob")
    A.add("Tom")
    A.add("Joe")
    A.add("Coe")

    A.add("Bob2")
    A.add("Tom2")
    A.add("Joe2")
    A.add("Coe2")

    for i in A:
        print(i)这里插入代码片

上面的代码,只用了一个类,类中增加了2个方法,就能够完成迭代器的工作,

算是本篇文章的核心点吧,现在已经完成了一个对象的可迭代
​结果和之前的一样,功能实现,帮助自己对迭代器的理解
​​

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168452.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • hackbar2.2.9在Firefox中的安装

    hackbar2.2.9在Firefox中的安装转载出处:https://www.ddosi.com/b320/尊重原创,以及知识产权,首先声明这是上面链接中大神的辛苦劳动成果,因为不知道如果联系所以这篇转载可能会有侵权问题,希望查看此链接的爱好者直接点击上面的链接查看,这篇仅是个人学习转载。前言众所周知,Firefox的插件必须经过签名,才能加载到浏览器中.因此,对于hackbar的破解,要么是装2.1.3这个没有激活的老版本,要么是直接安装hackbar的替代品,如Machackbar……其实对于h.

    2022年5月15日
    76
  • python爬虫scrapy框架_python主流爬虫框架

    python爬虫scrapy框架_python主流爬虫框架闲来无聊,写了一个爬虫程序获取百度疫情数据。申明一下,研究而已。而且页面应该会进程做反爬处理,可能需要调整对应xpath。

    2022年10月9日
    2
  • 陶瓷电容分类_陶瓷电容电压级别分类

    陶瓷电容分类_陶瓷电容电压级别分类陶瓷电容分为贴装陶瓷电容和插装陶瓷电容两大类。贴装陶瓷电容是多层陶瓷电容,一般耐压不会超过50V,而层数可以达到4000层,插装的陶瓷电容中包括圆片陶瓷电容和独石电容。圆片陶瓷电容也称瓷片电容,是单层的,耐压从50V~6000V都较为普遍。同样容值下,瓷片电容受温度影响更小,更适合应用在微弱信号放大电路的滤波中。独石电容全称是片式多层陶瓷电容器,(网上有资料说其实就是陶瓷贴片电容的

    2022年8月22日
    5
  • p2p流媒体平台有哪些(p2p工作模式)

    P2P流媒体开源项目介绍1.PeerCast2002年成立,最早的开源P2P流媒体项目。PeerCast把节点按树结构组织起来,每个频道都是一个树,直播源是根节点,父节点只给子节点提供数据。节点离根节点越远,传输时延就越大,所以树的深度应该尽可能短,但节点有限的上行带宽限制了节点的宽度。 2.Tribler2008年开始的项目,既能实现BT下载,还能播放视频的点播和直播…

    2022年4月17日
    77
  • 客服系统源码购买_网联接入商户扣款

    客服系统源码购买_网联接入商户扣款介绍:客服系统多种商户接入客服源码,可以实现一行代码接入客服,非常舒服,支持无限客服,无限坐席!私有化源码部署,数据可控,稳定可靠。可自定义版权、logo。支持网页、微信公众号、小程序、App等任何程序对接。客服数量不限,每个客服又独立管理后台和账户密码。每个账户管理可以添加N个客服并且可以分组。双向微信模板消息通知。支持商品推送,对客服评价。支持客户分组。支持设置问候语,进入对话自动发送消息,可只能分配客服和转接。网盘下载地址:http://kekewl.cc/Evr7Jd0UX7h图

    2022年9月21日
    5
  • 商品搜索——输入联想|智能提示探索

    商品搜索——输入联想|智能提示探索

    2020年11月12日
    235

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号