【python学习】python的生成器和装饰器

中国史之【钧台之享】:
钧台,古台名(今河南省禹州市),泛指帝王游乐的台观。《左传》昭公四年载“夏启有钧台之享”,是指夏启在袭位后,召集各路诸侯或部落首领在钧台举行大型宴会,表示自己正式继承王位。
-来源:全历史APP

今天讲python的生成器和装饰器。有需要的也可以直接去我的github查看全部笔记:
https://github.com/JackKoLing/python_notes_with_ten_days
在这里插入图片描述
俗话说:“好记性不如烂笔头”,多写写多记记,总不会错。多一些不为什么的坚持,少一些功利主义的追求。对于环境的配置,可以参考以下两篇:

1 简单示例

# 生成110的平方
for i in (j**2 for j in range(1, 11)):
    print(i)
>>>
1
4
9
16
25
36
49
64
81
100
# 也可以转为列表
print(list(i**2 for i in range(1, 11)))
>>>
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

2 生成器(generator)

  • 生成器是指含有yield的函数
  • 在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回 yield 的值
  • 并在下一次执行next() 方法时从当前位置继续运行
  • 因为yield可以返回,所以不需要写return语句
# 也可以使用含有yield的函数来生成
def gen_num(x):
    i = 1
    while i <= x:
        yield i**2 # 遇到yield就返回其后面的信息
        i += 1

g1 = gen_num(10) # 返回的是生成器对象
print(type(g1))

# print(next(g1)) # 输出一个

for i in g1:
    print(i)
>>>
<class 'generator'>
1
4
9
16
25
36
49
64
81
100

3 装饰器(decorator)

  • 装饰器本身就是一个函数,用于装饰其他函数
  • 用于增强被装饰函数的功能
  • 一般接受一个函数对象作为参数,以对其进行增强
# 使用闭包定义一个装饰器,通过@来引用装饰器
def deco(func):
    def wrapper(x):
        print("please say something:")
        func(x)
        print("No zuo no die.")
    return wrapper

@deco
def show(x):
    print(x)

show("I am from Mars.") # 原来函数只说一句话,现在将其增强为说三句话
>>>
please say something:
I am from Mars.
No zuo no die

【声明】:学习笔记基于互联网上各种学习资源的个人整理。

以上是本期内容,下期介绍python的递归函数和函数的设计规范。

我叫小保,一名计算机视觉爱好者、学习者、追随者,欢迎关注我一起学习。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Python中的迭代器、生成器装饰器都是非常重要的编程概念,下面分别介绍一下: 1. 迭代器 Python中的迭代器是一种可以遍历集合中元素的对象,可以使用for循环遍历集合中的元素。迭代器实现了两个方法:__iter__()和__next__()。__iter__()方法返回迭代器对象自身,__next__()方法返回集合中的下一个元素。 下面是一个简单的使用迭代器遍历列表的示例: ``` my_list = [1, 2, 3] my_iterator = iter(my_list) for i in my_iterator: print(i) ``` 2. 生成器 生成器是一种特殊的函数,可以在执行过程中多次返回值,而不是只返回一次。生成器使用yield语句返回值,可以暂停函数的执行,并在需要时继续执行。 下面是一个简单的生成器示例: ``` def my_generator(): yield 1 yield 2 yield 3 for i in my_generator(): print(i) ``` 3. 装饰器 装饰器是一种可以修改函数或类的行为的函数,可以在不修改原始代码的情况下添加额外的功能。装饰器本质上是一个可以接受函数或类作为参数的函数,可以在不修改原始函数或类的情况下修改其行为。 下面是一个简单的装饰器示例: ``` def my_decorator(func): def wrapper(): print("Before the function is called.") func() print("After the function is called.") return wrapper @my_decorator def my_function(): print("Inside the function.") my_function() ``` 在上面的代码中,我们定义了一个装饰器函数my_decorator,它接受一个函数作为参数,并返回一个新的函数wrapper。这个新函数在调用原始函数之前和之后打印一些文本。我们使用@符号将装饰器应用到my_function函数上,这样my_function函数的行为就被修改了。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JackkoLing

感谢你的支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值