python-生成器函数进阶和各种推导式day15

def generator():
    for i in range(20000):
        yield "哇哈哈%s"%(i)
g=generator()
ret=g.__next__()
print(ret)
num=0
for i in g:
    num+=1
    if num>50:
        break
    print(i)
#从生成器中取值方法
    #next
    #for
    #数据类型转换:占内存

 生成器的进阶和各种推导式:

def generator():
    print(1)
    content=yield 1
    print('===',content)
    yield 2
g=generator() #生成器
ret=g.__next__() #进行第一次迭代
print(ret)
ret2=g.send("你好啊") #进行第二次迭代
print(ret2)
#send方法域next方法类似
#使用send注意事项:
    #第一次使用生成器是只能用next
    #最后一个yield不能接受外部的传值
#移动平均值
def init(func):
    def inner(*args,**kwargs):
        g=func(*args,**kwargs)
        g.__next__()
        return g
    return inner
@init
def average():
    sum=0
    count=0
    avg=0
    while True:
        num=yield avg
        sum+=num
        count+=1
        avg=sum/count
avg_g=average()
ret=avg_g.send(10)
print(ret)
ret=avg_g.send(20)
print(ret)
ret=avg_g.send(11)
print(ret)
def generator2():
    a="asdasd"
    b="13124"
    yield from a  #等价于 for i in a: print(i)
    yield from b
g=generator2()
for i in g:
    print(i)

#[每一个元素或者元素相关的操作 for 元素 in 可迭代数据类型]
#[满足条件的元素相关的操作 for 元素 in 可迭代数据类型 if 元素相关的条件] #30以内能被3整出的平方 ret = [i**2 for i in range(30) if i%3==0] print(ret) #找到嵌套列表中名字含有两个‘e’的所有名字 names = [['Tom', 'Billy', 'Jefferson', 'Andrew', 'Wesley', 'Steven', 'Joe'], ['Alice', 'Jill', 'Ana', 'Wendy', 'Jennifer', 'Sherry', 'Eva']] name=[name for lst in names for name in lst if name.count('e')==2] print(name) #将一个字典的key和Value对调 dic={'a':10,'b':39} dic_sort={dic[k]:k for k in dic} print(dic_sort)

 

转载于:https://www.cnblogs.com/orange126/p/10878019.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值