流程的Python(十五)-上下文管理器和else块

一、核心要义

1. for, while和try语句的else字句

2. with语句和上下文管理器

二、代码示例

1、else块

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2024/2/28 20:14
# @Author  : Maple
# @File    : 01-else块.py
# @Software: PyCharm"""
用在for循环,while语句 和try...except中的else块
"""
from random import  randintdef gen():return randint(1,6)if __name__ == '__main__':# 1.for循环中 else的使用:只有当for循环正常遍历完,才会执行elseprint('****1.for循环中 else的使用***********')my_list = ['Maple','Kelly']for i in my_list:if 'Max' == i :breakelse:print('Max is not in mylist')# 2.while语句中else块使用:没有被break语句中止,顺利循环执行完毕,才会执行else模块中的语句print('****2.while语句中else的使用***********')i = 0while  i < 3:i +=1if gen() == 1:breakelse:print('while顺利执行完毕')# 3 try..except中使用else:没有错误被捕获时,才会执行elseprint('****3.try..except语句中else的使用***********')try:print(1)except Exception as e:print(e)else:print('没有错误,顺利执行完毕')

2、上下文管理器和with块

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2024/2/28 20:33
# @Author  : Maple
# @File    : 02-上下文管理器和with块.py
# @Software: PyCharmdef fun():with open('data/scores') as fp:"""1. with open() 返回的是一个上下文管理器(包含__enter__和__exit__方法),此例中的上下文管理器是TextIOWrapper类的实例,with语句在开始运行的时候就会进入管理器的__enter__方法2. __enter__方法返回的对象,通过as 语句赋值给fp,此例__enter__方法返回的刚好的是管理器本身(self).其实__enter__方法也可以返回其它值,甚至是None(此时with语句也无需通过as接收值)"""lines = fp.readlines()for line in lines:print(line)class LookingGlass:def __enter__(self):import sysself.original_write = sys.stdout.write# 将标准输出反向sys.stdout.write = self.reverse_writereturn 'JABBERWOCKY'def reverse_write(self,text):self.original_write(text[::-1])def __exit__(self, exc_type, exc_val, exc_tb):import syssys.stdout.write = self.original_writeif exc_type is ZeroDivisionError:print(r"Please don't divide by zero!")# 告诉解释器,异常已经处理return True# 如果exit方法返回None,或者True之外的值,with块中的任何异常都会向上冒泡if __name__ == '__main__':# 1. fun函数测试"""100 200 300400 500 600"""fun()# 2.使用 LookingGlass# LookingGlass类enter方法的返回值 JABBERWOCKY 会赋值给whatwith LookingGlass() as what:# 由于标准输出已经反向,所以下面的字符也会反向输出print('Alice,Kitty and Snowdrop') # pordwonS dna yttiK,ecilA# JABBERWOCKY反向输出print(what) # YKCOWREBBAJ# with语句结束, sys.stdout.write恢复成正常,所以what会正常输出print(what) # JABBERWOCKY# 3.with语句之外使用 LookingGlassprint('****3.with语句之外使用 LookingGlass***********')manager = LookingGlass()## 执行完之后 标注输出就反向了monster = manager.__enter__()print(monster) # YKCOWREBBAJ## 执行完exit方法,标准输出恢复正常manager.__exit__(None,None,None)print(monster) # JABBERWOCKY

3、contextmanager

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2024/2/28 22:12
# @Author  : Maple
# @File    : 03-contextmanager.py
# @Software: PyCharm"""
该装饰器将简单的生成器函数变成 上下文管理器,这样就不用创建类去 实现管理器协议
"""
from contextlib import contextmanager"""contextmanager的功能:把生成器包装成实现了__enter__和__exit__方法的类
1.__enter__方法的作用:
(1)调用生成器函数,保存生成器对象(这里将其称为gen)
(2)调用next(gen),执行到yield关键字所在的位置
(3)返回next(gen)产出的值,绑定到with/as 语句中的目标变量上
2.__exit__方法的作用:
(1)检查有没有把异常传给exc_type,如果有,调用gen.throw(exception),在生成器函数定义体中包含yield关键字的那一行抛出异常**注意:如果生成器函数中,没有处理异常的代码,生成器函数就会终止(在yield行),不会执行下面的代码,因此可能导致有些收尾工作无法完成
(2)否则,调用next(gen),继续执行生成器函数定义体中yield语句之后的代码Tips:在@contextmanager装饰器装饰的生成器中,yield与迭代没有任何关系,更像是协程:执行到某一点暂停,让客户代码运行,直到客户让协程继续运行
"""@contextmanager
def LookingGlass():import sysoriginal_write = sys.stdout.writemsg = ''def reverse_write(text):original_write(text[::-1])# 将标准输出反向sys.stdout.write = reverse_write# yield之前的部分,相当于是上下文管理器的__enter__函数内容# 为了避免因为抛出异常,yield之后的代码无法执行,这里写成try..except..finally的形式try:yield 'JABBERWOCKY'# yield之后的部分,相当于是上下文管理器的__exit__函数内容except ZeroDivisionError:msg = 'please do not divide by zero!'finally:sys.stdout.write = original_writeif msg:print(msg)if __name__ == '__main__':with LookingGlass() as what:# 由于标准输出已经反向,所以下面的字符也会反向输出print('Alice,Kitty and Snowdrop')  # pordwonS dna yttiK,ecilA# JABBERWOCKY反向输出print(what)  # YKCOWREBBAJprint(what) # JABBERWOCKY

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/711696.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

lottie加载带图片的json 预览

背景 产品看到一款app的动效很不错&#xff0c;让我去模仿实现。 第一步 获取apk中的静态资源 拿到这个app的apk后&#xff0c;直接使用压缩工具解压&#xff0c; assets文件夹就是静态资源的目录 静态资源里面有lottie 那么大部分的动效应该都是lottie实现的 网上找了很多…

一些常见的SpringBoot面试题

以下是一些常见的SpringBoot面试题&#xff1a; 1. 什么是SpringBoot&#xff1f; * SpringBoot是一个开源的Java框架&#xff0c;用于简化Spring应用程序的创建和部署。它提供了许多内置的功能&#xff0c;如自动配置、嵌入式Web服务器、安全性、健康检查等&#xff0c;使得…

经销商文件分发 怎样兼顾安全和效率?

经销商文件分发是指将文件、资料、产品信息等从制造商或经销商传递给经销商的过程。这一过程对于确保经销商能够获取最新的产品信息、销售策略、市场活动资料等至关重要。 想要管理众多经销商合作伙伴之间的文件传输并提高效率&#xff0c;可以采取以下措施&#xff1a; 1、建…

机器学习 -- 梯度下降算法加深

梯度下降算法 在机器学习中&#xff0c;梯度下降算法常用于最小化代价函数&#xff08;或损失函数&#xff09;&#xff0c;以此来优化模型的参数。代价函数衡量的是模型预测值与实际值之间的差异。通过最小化这个函数&#xff0c;我们可以找到模型预测最准确的参数。 代价函…

数字快速增长动画插件vue-countupjs

使用场景&#xff1a; ①页面加载时实现数字从0开始滚到指定数字 ②大屏数字的滚动增长 1.安装vue-countupjs npm install vue-countupjs --save 2.使用 ①全局使用 main.js引入 import VueCountUp from vue-countupjs Vue.use(VueCountUp) Vue.component(VueCountUp, Vue…

Mybatis-Plus-快速整合

Mybatis-Plus 依赖 依赖选择 <!-- 最新版本 --> <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.5</version> </dependency>配置 分页 分页拦截器配置…

易毅出席成套低温烘干装备在发酵行业的节能创新应用

演讲嘉宾&#xff1a;易毅 总经理 广东芬蓝环境科技有限公司 演讲题目&#xff1a;成套低温烘干装备在发酵行业领域的节能创新应用 会议简介 “十四五”规划中提出&#xff0c;提高工业、能源领城智能化与信息化融合&#xff0c;明确“低碳经济”新的战略目标&#xff0c;热…

Unity2023.1.19_Socket-TCP_ 服务端与客户端通讯基础

Unity2023.1.19_Socket-TCP_ 服务端与客户端通讯基础 目录 Unity2023.1.19_Socket-TCP_ 服务端与客户端通讯基础

python-分享篇-根据出生日期判断你的星座出生日期判断生肖

文章目录 根据出生日期判断你的星座出生日期判断生肖 根据出生日期判断你的星座 sdate[20,19,21,20,21,22,23,23,23,24,23,22] # 星座判断列表 conts [摩羯座,水瓶座,双鱼座,白羊座,金牛座,双子座,巨蟹座,狮子座,处女座,天秤座,天蝎座,射手座,摩羯座] signs[♑,♒,♓,♈,♉…

测试计划(详细版)

测试计划Testing plan&#xff0c;描述了要进行的测试活动的范围、方法、资源和进度的文档&#xff1b;是对整个信息系统应用软件组装测试和确认测试。 [1] 它确定测试项、被测特性、测试任务、谁执行任务、各种可能的风险。测试计划可以有效预防计划的风险&#xff0c;保障计…

JPEG support not enabled.

报错&#xff1a; ECCODES ERROR : JPEG support not enabled. ECCODES ERROR : unable to get values as double array (Functionality not enabled) ECCODES ERROR : Unable to create iterator bFunctionality not enabled 在linux中运行python代码的时候报错了&…

Baumer工业相机堡盟工业相机如何联合GAPI SDK和OpenCV实现相机图像将图像转换为Mat格式再转为Bitmap图像进行显示(C#)

Baumer工业相机堡盟工业相机如何联合GAPI SDK和OpenCV实现相机图像将图像转换为Mat图像格式再转为Bitmap图像进行显示&#xff08;C#&#xff09; Baumer工业相机Baumer工业相机的图像转换为OpenCV的Mat图像的技术背景代码分析第一步&#xff1a;先引用OpenCV库第二步&#xff…

贪心 Leetcode 56 合并区间

合并区间 Leetcode 56 学习记录自代码随想录 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中的所有区间 。 示例 1…

C++的继承和多态

继承和多态 继承继承的权限继承的子父类访问派生类的默认成员函数菱形继承&#xff08;C独有&#xff09;【了解】虚拟继承什么是菱形继承&#xff1f;菱形继承的问题是什么&#xff1f;什么是菱形虚拟继承&#xff1f;如何解决数据冗余和二义性的继承和组合的区别&#xff1f;…

揭秘Android Tombstone:崩溃位置的秘密研究-Crash Location

由于一些工作原因&#xff0c;最近对Android系统发生crash的Tombstone展开了一定的研究。 这里我谈一下关于对于Android Libstagefright 整数溢出漏洞的crash Tombstone的研究。看一下在包含整数溢出功能的MP4文件从PC传输进Android的时候造成的Tombstone0_0。 1、研究头部信…

双通道 40V 160mΩ车规级高侧电源开关带诊断功能反向电池保护功能

概述 PC8916是双通道、高功率具有集成NMOS功率FET的开关&#xff0c;以及电荷泵。该设备集成了高级 保护功能&#xff0c;例如负载电流限制&#xff0c;通过功率限制进行过载主动管理带可配置闭锁的超温停机。全面诊断和高精度电流感应这些功能实现了对负载的智能控制。有源漏…

[C++] 统计程序耗时

一、简介 使用clock()函数记录程序开始、结束时间戳。然后将开始结束时间戳差除以CLOCKS_PER_SEC得到程序的耗用的时间&#xff08;秒数&#xff09;。 二、代码示例 #include <iostream> #include <time.h> #include <math.h> int main(int, char **) {clo…

JetPack 5.1编译mish_cuda

1.查看jetpack版本:sudo jtop 自带的就有cuda11.4和cudnn8.X以及python3.8,我的cudnn就没有是后期自己安装的 2.安装torch PyTorch for Jetson - Announcements - NVIDIA Developer Forums 选择对应的cuda版本和torch版本,我下载的是:torch-2.1.0a0+41361538.nv23.06-cp…

ETL数据仓库的使用方式

一、ETL的过程 在 ETL 过程中&#xff0c;数据从源系统中抽取&#xff08;Extract&#xff09;&#xff0c;经过各种转换&#xff08;Transform&#xff09;操作&#xff0c;最后加载&#xff08;Load&#xff09;到目标数据仓库中。以下是 ETL 数仓流程的基本步骤&#xff1a…

2024中国5G随身WiFi十大品牌排行榜,20245G随身口碑排行榜,5G随身WiFi2024最新款!5G随身WiFi推荐测评

【中国品牌网中国3C质量评测中心权威榜单联合发布】 第一名&#xff1a;格行5G随身WiFi&#xff1a; 优点&#xff1a;随身WiFi行业的头部和领跑品牌&#xff0c;15年专业物联网行业经验&#xff0c;格行在技术研发、产品创新和客户服务方面具有很高的口碑&#xff0c;被业内…