知识点

else语句的用法:

  • 1)配合if语句
if a>b:
print(a)
else:
print(b)
  • 2)配合while和for循环

    只在循环完成后才执行,如果循环中执行使用到break,则else不执行

#*************************************************#
# 判断给定数的最大公约数,如果是素数,则打印 #
#*************************************************#
def showMaxFactor(num):
count = num//2
while count > 1:
if num %count == 0:
print('%d最大的约数是%d'%(num,count))
break
count -= 1
else:
print('%d是素数!'%num) num = int(input('请输入一个数:'))
showMaxFactor(num)
  • 3)与异常处理语句搭配

如果没有出错,则打印出‘没有任何错误!’

try:
print(int('abc'))
except ValueError as reason:
print('出错啦:' + reason)
else:
print('没有任何异常!')

with语句

可以参考浅谈 Python 的 with 语句文章

  • with 语句的语法格式如下:
with context_expression [as target(s)]:
with-body

这里 context_expression要返回一个上下文管理器对象,该对象并不赋值给as 子句中的 target(s) ,如果指定了 as 子句的话,会将上下文管理器的 __enter__()方法的返回值赋值给 target(s)。target(s) 可以是单个变量,或者由()括起来的元组(不能是仅仅由“,”分隔的变量列表,必须加“()”)。

Python 对一些内建对象进行改进,加入了对上下文管理器的支持,可以用于 with 语句中,比如可以自动关闭文件、线程锁的自动获取和释放等。假设要对一个文件进行操作,使用 with 语句可以有如下代码:

#*********************************************#
# 异常处理配合with语句 #
# 可以避免已打开文件没关闭的情况 #
#*********************************************#
try:
with open('data.txt','w') as f:
for each_line in f:
print(each_line)
except OSError as reason:
print('出错啦:' + str(reason))

这里使用了 with 语句,不管在处理文件过程中是否发生异常,都能保证 with 语句执行完毕后已经关闭了打开的文件句柄。

如果使用传统的try/finally 范式,则要使用类似如下代码:

try:
f = open('data.txt','w')
for each_line in f:
print(each_line)
except OSError as reason:
print('出错啦:' + str(reason))
finally:
f.close()

课后习题

测试题:

  • 使用with语句固然方便,但如果出现异常的话,文件还会自动正常关闭吗?

with语句会自动处理文件的打开和关闭,如果中途出现异常,会执行清理代码,然后确保文件自动关闭。
  • 你可以换一种形式写出下边的伪代码吗?
with A() as a:
with B() as b:
suite

with语句处理多个项目的时候,可以用逗号隔开写成一条语句

with A() as a, B() as b:
suite

动动手:

  • 使用with语句改写以下代码,让python去关心文件的打开与关闭吧
def file_compare(file1, file2):
f1 = open(file1)
f2 = open(file2)
count = 0 # 统计行数
differ = [] # 统计不一样的数量 for line1 in f1:
line2 = f2.readline()
count += 1
if line1 != line2:
differ.append(count) f1.close()
f2.close()
return differ file1 = input('请输入需要比较的头一个文件名:')
file2 = input('请输入需要比较的另一个文件名:') differ = file_compare(file1, file2) if len(differ) == 0:
print('两个文件完全一样!')
else:
print('两个文件共有【%d】处不同:' % len(differ))
for each in differ:
print('第 %d 行不一样' % each)

使用with语句处理文件可以减少需要编写的代码量和粗心的错误

def file_compare(file1, file2):
with open(file1) as f1, open(file2) as f2:
count = 0 # 统计行数
differ = [] # 统计不一样的数量 for line1 in f1:
line2 = f2.readline()
count += 1
if line1 != line2:
differ.append(count)
return differ file1 = input('请输入需要比较的头一个文件名:')
file2 = input('请输入需要比较的另一个文件名:') differ = file_compare(file1, file2) if len(differ) == 0:
print('两个文件完全一样!')
else:
print('两个文件共有【%d】处不同:' % len(differ))
for each in differ:
print('第 %d 行不一样' % each)
  • 你可以利用异常的原理,修改下面的代码使得更高效率的实现吗?
print('|--- 欢迎进入通讯录程序 ---|')
print('|--- 1:查询联系人资料 ---|')
print('|--- 2:插入新的联系人 ---|')
print('|--- 3:删除已有联系人 ---|')
print('|--- 4:退出通讯录程序 ---|') contacts = dict() while 1:
instr = int(input('\n请输入相关的指令代码:')) if instr == 1:
name = input('请输入联系人姓名:')
if name in contacts:
print(name + ' : ' + contacts[name])
else:
print('您输入的姓名不再通讯录中!') if instr == 2:
name = input('请输入联系人姓名:')
if name in contacts:
print('您输入的姓名在通讯录中已存在 -->> ', end='')
print(name + ' : ' + contacts[name])
if input('是否修改用户资料(YES/NO):') == 'YES':
contacts[name] = input('请输入用户联系电话:')
else:
contacts[name] = input('请输入用户联系电话:') if instr == 3:
name = input('请输入联系人姓名:')
if name in contacts:
del(contacts[name]) # 也可以使用dict.pop()
else:
print('您输入的联系人不存在。') if instr == 4:
break print('|--- 感谢使用通讯录程序 ---|')

使用条件语句的代码非常直观明了,但是效率不高。因为程序会两次访问字典的键,一次判断是否存在(if name in contacts),一次获得值(例如:print(name + ' : ' + contacts[name]

如果利用异常解决方案,我们可以简单避开每次需要使用in判断是否key存在字典中的操作。

因为只要当key不存在字典中时,会触发KeyError异常,利用此特性我们可以修改代码如下:

print('|--- 欢迎进入通讯录程序 ---|')
print('|--- 1:查询联系人资料 ---|')
print('|--- 2:插入新的联系人 ---|')
print('|--- 3:删除已有联系人 ---|')
print('|--- 4:退出通讯录程序 ---|') contacts = dict() while 1:
instr = int(input('\n请输入相关的指令代码:')) if instr == 1:
name = input('请输入联系人姓名:')
try:
print(name + ' : ' + contacts[name])
except KeyError:
print('您输入的姓名不再通讯录中!') if instr == 2:
name = input('请输入联系人姓名:')
try:
contacts[name] # 有点“为赋新词强说愁”的感觉
print('您输入的姓名在通讯录中已存在 -->> ', end='')
print(name + ' : ' + contacts[name])
if input('是否修改用户资料(YES/NO):') == 'YES':
contacts[name] = input('请输入用户联系电话:')
except KeyError:
contacts[name] = input('请输入用户联系电话:') if instr == 3:
name = input('请输入联系人姓名:')
try:
del(contacts[name]) # 也可以使用dict.pop()
except KeyError:
print('您输入的联系人不存在。') if instr == 4:
break print('|--- 感谢使用通讯录程序 ---|')

零基础入门学习Python(34)--丰富的else语句及简洁的with语句的更多相关文章

  1. 【Python教程】《零基础入门学习Python》(小甲鱼)

    [Python教程]<零基础入门学习Python>(小甲鱼) 讲解通俗易懂,诙谐. 哈哈哈. https://www.bilibili.com/video/av27789609

  2. 《零基础入门学习Python》【第一版】视频课后答案第001讲

    测试题答案: 0. Python 是什么类型的语言? Python是脚本语言 脚本语言(Scripting language)是电脑编程语言,因此也能让开发者藉以编写出让电脑听命行事的程序.以简单的方 ...

  3. 零基础入门学习Python(1)--我和Python的第一次亲密接触

    前言 最近在学习Python编程语言,于是乎就在网上找资源.其中小甲鱼<零基础入门学习Python>试听了几节课,感觉还挺不错,里面的视频都是免费下载,小甲鱼讲话也挺幽默风趣的,所以呢,就 ...

  4. 学习参考《零基础入门学习Python》电子书PDF+笔记+课后题及答案

    国内编写的关于python入门的书,初学者可以看看. 参考: <零基础入门学习Python>电子书PDF+笔记+课后题及答案 Python3入门必备; 小甲鱼手把手教授Python; 包含 ...

  5. 学习《零基础入门学习Python》电子书PDF+笔记+课后题及答案

    初学python入门建议学习<零基础入门学习Python>.适合新手入门,很简单很易懂.前一半将语法,后一半讲了实际的应用. Python3入门必备,小甲鱼手把手教授Python,包含电子 ...

  6. 零基础入门学习Python(36)--类和对象:给大家介绍对象

    知识点 Python3 面向对象 Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对象是很容易的.本章节我们将详细介绍Python的面向对象编程. 如果你以前 ...

  7. 零基础入门学习Python(17)--函数:Python的乐高积木

    前言 相信大家小时候都玩过神奇的乐高积木, 只要通过想象力和创造力我们可以拼凑很多神奇的东西,那么随着我们学习的深入,我们编写的Python代码也将日益增加,并且也越来越复杂, 所以呢,我们需要找寻一 ...

  8. 零基础入门学习Python(33)--异常处理:你不可能总是对的2

    知识点 异常处理 捕捉异常可以使用try/except语句. try/except语句用来检测try语句块中的错误,从而让except语句捕获异常信息并处理. 如果你不想在异常发生时结束你的程序,只需 ...

  9. 零基础入门学习Python(35)--图形用户界面入门:EasyGui

    知识点 EasyGui学习文档[超详细中文版] 1. 建议不要在IDLE上运行EasyGui EasyGui是运行在TKinter上并拥有自身的事件循环,而IDLE也是Tkinter写的一个应用程序并 ...

随机推荐

  1. bzoj 1661: [Usaco2006 Nov]Big Square 巨大正方形【枚举】

    每句两个顶点确定正方形,取max即可 #include<iostream> #include<cstdio> using namespace std; int n,x,y,s, ...

  2. bzoj 2508: 简单题【拉格朗日乘数法】

    大概是对于f(x,y)求min,先把x看成常数,然后得到关于y的一元二次方程,然后取一元二次极值把y用x表示,再把x作为未知数带回去化简,最后能得到一个一元二次的式子,每次修改这个式子的参数即可. 智 ...

  3. [App Store Connect帮助]七、在 App Store 上发行(2.2)设定价格与销售范围:将您的 App 以预订形式发布

    在首次将您的 App 发布至 App Store 前,您可以选择以预订形式提供该 App.在您的 App 发布以供下载之前,顾客可以查看您的产品页并订购您的 App.您的 App 一旦发布,顾客将会收 ...

  4. NOIp 2010/Luogu P1525 关押罪犯 【二分图/并查集】 By cellur925

    题目传送门 感想:相信自己的想法!继续挖掘! 读完题目后:看到的最大值最小?二分答案啊!再仔细一看:wi达到了1e9,二分可能费点劲.(其实真的是可以的)而且check函数貌似并没有什么行之有效的写法 ...

  5. jsp标准标签库——jstl

    JSP标准标签库(JSTL)是一个JSP标签集合,它封装了JSP应用的通用核心功能. JSTL支持通用的.结构化的任务,比如迭代,条件判断,XML文档操作,国际化标签,SQL标签. 除了这些,它还提供 ...

  6. Qt事件系统之三:键盘事件

    QKeyEvent类用来描述一个键盘事件.当键盘按键被按下或者被释放时,键盘事件便会被发送给拥有键盘输人焦点的部件. QKeyEvent的key()函数可以获取具体的按键,对于Qt中给定的所有按键,可 ...

  7. _bzoj3223 Tyvj 1729 文艺平衡树【Splay】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3223 裸的,打个标记. #include <cstdio> #include & ...

  8. 如何移除EditText自动焦点

    <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_cont ...

  9. 窗体WINFORM

    窗体的事件:删除事件:先将事件页面里面的挂好的事件删除,再删后台代码里面的事件 Panel是一个容器 1.Label -- 文本显示工具Text:显示的文字取值.赋值:lable1.Text 2.Te ...

  10. SQL SERVER 事务例子

    存储过程格式: CREATE PROCEDURE YourProcedure AS BEGIN SET NOCOUNT ON; BEGIN TRY---------------------开始捕捉异常 ...