标签:gen yield def 内存 地方 for shu cti object
学完函数,我们还需要知道一些让我们能够提高效率的高级特性:
>>> def plusitem(pam): ... return pam*pam ... >>> type(plusitem) <class ‘function‘> >>> plusitem(12) 144 >>> nonamefuc=lambda item:item*item >>> type(nonamefuc) <class ‘function‘> >>> nonamefuc(12) 144
说明:lambda表达式就是一个函数昂。
在不知道有列表推导式之前,我们想要生成一个[1,2,3...,9]的列表,是这样子写的 :
>>> mylis=[] >>> for item in range(1,10): ... mylis.append(item) ... >>> mylis [1, 2, 3, 4, 5, 6, 7, 8, 9]
如果我们有了列表推导式,可以十分简洁地生成一个列表:
>>> newlis=[item for item in range(1,10)] >>> newlis [1, 2, 3, 4, 5, 6, 7, 8, 9]
列表推导式的花式玩法:
>>> jishulis=[x for x in range(1,10) if x%2==1] >>> jishulis [1, 3, 5, 7, 9]
>>> shuangceng=[x*y for x in range(1,10) for y in [1,2,3]] >>> shuangceng [1, 2, 3, 2, 4, 6, 3, 6, 9, 4, 8, 12, 5, 10, 15, 6, 12, 18, 7, 14, 21, 8, 16, 24, 9, 18, 27]
一种可以被遍历的对象,并且可以作用于next()函数。迭代器对象从第一个元素访问,直到所有的元素被访问完才结束。迭代器只能往后遍历不能回溯。迭代器常用的两个方法iter()和next()。
我的理解就是:
>>> from collections import Iterable >>> isinstance(‘123‘,Iterable) True >>> isinstance(123,Iterable) False >>> lis=[1,2,3,4] >>> lis [1, 2, 3, 4] >>> it=iter(lis) >>> it <list_iterator object at 0x0000021E54846BE0> >>> next(it) 1 >>> for x in it: ... print(x) ... 2 3 4
说明:iter()可以创建迭代器,使用next()可以获取迭代器的下一个元素。for循环可以遍历迭代器。python中的for循环本质上就是通过next()函数实现的。
有时候列表内的元素个数非常巨大,一下子制造出来放到内存中是内存压力会很大。我们可以通过某种算法把元素推算出来,用到哪儿时再计算出来使用。这就是生成器的作用。
>>> g=(x for x in [2,4,6,8,10]) >>> g <generator object <genexpr> at 0x0000021E5498C270> >>> g[0] Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: ‘generator‘ object is not subscriptable >>> next(g) 2 >>> for item in g: ... print(item) ... 4 6 8 10
使用yield关键字可以让一个函数制造出一个生成器。
比如下面,返回一个列表元素的平方。
>>> def genfunc(pams): ... print(‘开始了..‘) ... for item in pams: ... yield item*item ... >>> lis=[1,2,3,4,5] >>> rtn=genfunc(lis) >>> rtn <generator object genfunc at 0x000001B6598795F0> >>> next(rtn) 开始了.. 1 >>> next(rtn) 4
说明:
Python--Demo13--高级特性匿名函数、推导式、迭代器、生成器
标签:gen yield def 内存 地方 for shu cti object
原文地址:https://www.cnblogs.com/bigbosscyb/p/12350022.html