赞
踩
python能够去用来实现很多不同方向的程序开发,而大数据和数据处理方向就是Python的强项之一。而在有很多的数据时一次性将其处理速度就会很慢,甚至出现内存溢出问题。那么这个时候就要用生成器来拆分数据了,下文会有详细代码示例解析。
无论是在什么样的服务器上使用python处理数据,当数据量非常大的时候都不能够一次性的将其处理掉,而需要将大数据拆分为多个小数据再进行处理,这样既能提高程序运行速度又可以合理利用内存。
而要实现这个需求就要用到生成器了,python之中的生成器实际上就是一个可迭代对象,或者说是每次都会生成一个值返回的函数。而生成器只需要通过yeild关键字即可创建,示例如下:
- def chunker(iterable,size):
- for i in range(0,len(iterable),size):
- yield iterable[i:i+size]
在这个函数之中的两个参数分别为需要拆分的数据列表,以及拆分后每个保存数据的序列长度。而之所以会使用yeild来创建生成器是因为函数在每次执行完毕之后都会生成一个包含了大数据列表一部分数据的列表对象,如果不使用yeild创建生成器,函数在调用之后只会返回最后一次所拆分的数据。
而用了yeild关键字创建生成器则会将每次运行之后的结果返回给调用函数的位置并将当前状态保存下来,当下次调用这个生成器函数时就又会从保存的位置开始执行。这样就可以实现将数据拆分的功能,因为要返回多个数据列表,所以需要用for循环迭代调用函数,示例如下:
- for chunk in chunker(range(100),20):
- print(chunk)
以上就是关于“Python怎么使用生成器拆分数据?Python生成器拆分数据如何实现”的全部内容了,希望对你有所帮助。
关于Python技术储备
学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!
一、Python所有方向的学习路线
Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、Python必备开发工具
三、Python视频合集
观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、Python练习题
检查学习结果。
六、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
最后祝大家天天进步!!
上面这份完整版的Python全套学习资料已经上传至CSDN官方,朋友如果需要可以直接微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。