(原题:https://www.python123.io/student/courses/934/groups/8102/problems/programmings/6078)

Solution:

#方法一:异常处理与if单分支结合
n = input()
try:
if ("C" in n) or ("c" in n):
n = n.strip("Cc") #将字符串n的首尾的C与c全部去掉,实际上只需去掉末尾,但不影响
F = eval(n)*1.8 +32
print("{:.2f}".format(F)+"F") #或print("{:.2f}F".format(F))
else:
n = n.strip("Ff")
C = (eval(n)-32)/1.8
print("{:.2f}".format(C)+"C")
except:
print("输入格式错误")
#方法二:if-elif-else多分支与字符串切片(截取片断)结合
n = input()
if n[-1] in {"C","c"}:
n= n[0:-1]
F = eval(n)*1.8 +32
print("{:.2f}F".format(F))
elif n[-1] in {"F","f"}:
n = n[0:-1]
C = (eval(n)-32)/1.8
print("{:.2f}C".format(C))
else:
print("输入格式错误")

Notes:

(1)else在二分支、多分支中,为了把各中情况都考虑周全,有良好的用户体验,最好写上,否则虽然不满足前面那些条件,程序也不会报错,但也没有任何提示。执行时看起来像是程序没反应一样

(2)方法二中,因为else已经对用户不符合要求的输入进行了处理,所以不需再用try-except。因为这个只有在程序出现错误的时候才会执行except中的语句,报出相应的错误。如果程序不出错,即便不满足要求,也不会执行,画蛇添足。如:

执行结果:

即所有不正确的输入,都执行else语句,而不是except语句。

由此,可不可以去掉else,用except来替代呢?答案是否定的。如下:

n = input()
try:
if n[-1] in {"C","c"}:
n= n[0:-1]
F = eval(n)*1.8 +32
print("{:.2f}F".format(F))
elif n[-1] in {"F","f"}:
n = n[0:-1]
C = (eval(n)-32)/1.8
print("{:.2f}C".format(C))
except:
print("输入格式错误")

执行结果:

不报错:因为不管输入什么,程序都不会执行不了,所以异常处理时多余的

不提示:因为缺少了else对不满足条件的处理,所以不会返回任何结果

Statement:此为本人所学见解,不一定正确。如有不足之处,欢迎指正。分享随笔,一起进步

temperatureConversion1的更多相关文章

随机推荐

  1. akka 集群分片

    akka 集群 Sharding分片 分片上下级结构 集群(多台节点机) —> 每台节点机(1个片区) —> 每个片区(多个分片) —> 每个分片(多个实体) 实体: 分片管理的 A ...

  2. ZIP:ZipEntry

    ZipEntry: /* 此类用于表示 ZIP 文件条目. */ ZipEntry(String name) :使用指定名称创建新的 ZIP 条目. ZipEntry(ZipEntry e) :使用从 ...

  3. SP1805 HISTOGRA - Largest Rectangle in a Histogram 题解

    题目链接:https://www.luogu.org/problemnew/show/SP1805 分析: 我们可以用一个单调栈由低到高来存储它的高度,并用数组对每个高度记录一下它前面(包括它自己)一 ...

  4. Jmeter(1):使用TCP取样器与socket接口进行简单通信

    一个小任务:服务器与客户端连接,每次发送50个随机生成的字符,两秒发送一次 失败过太多次,然后昨晚终于跑通了,心情激动,于是清均第一篇博客就诞生了. 之前不了解jmeter,想过单纯用java编写服务 ...

  5. C#3.0新增功能10 表达式树 07 翻译(转换)表达式

    连载目录    [已更新最新开发文章,点击查看详细] 本篇将介绍如何访问表达式树中的每个节点,同时生成该表达式树的已修改副本. 以下是在两个重要方案中将使用的技巧. 第一种是了解表达式树表示的算法,以 ...

  6. [PTA] 数据结构与算法题目集 6-8 求二叉树高度 & 6-9 二叉树的遍历

    6.8 二叉树高度 int GetHeight(BinTree BT) { if (BT == NULL) return 0; int leftH = GetHeight(BT->Left); ...

  7. 盘一盘 synchronized (二)—— 偏向锁批量重偏向与批量撤销

    在本文讲解之前,先来简单了解一下为什么会有批量重偏向和批量撤销.   批量重偏向:当一个线程创建了大量对象并执行了初始的同步操作,后来另一个线程也来将这些对象作为锁对象进行操作,会导偏向锁重偏向的操作 ...

  8. 织梦(dede)底层模板概念、常用底层模板字段

    织梦(dede)底层模板概念.常用底层模板字段 一.底层模板的概念以及调用方式: 1. 什么是底层模板? 底层模板不是一个模板! 他就是在实际页面当中所要显示的具体内容: 2. 底层模板的应用: 调用 ...

  9. linux初学者-磁盘阵列篇

    linux初学者-磁盘阵列篇 在磁盘的使用中,有时候需要提高磁盘的读写数据速度,就要用到磁盘组——raid,也就是磁盘阵列. 磁盘阵列是由最少两块以上的磁盘组成的,raid有许多模式,在这里将介绍其中 ...

  10. TestNG中@Factory的用法一:简单的数据驱动

    为什么要使用@Factory注解呢,先来看下面这个例子 被测试类Person package ngtest; import org.testng.annotations.Parameters; imp ...