temperatureConversion1

(原题: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的更多相关文章
随机推荐
- akka 集群分片
akka 集群 Sharding分片 分片上下级结构 集群(多台节点机) —> 每台节点机(1个片区) —> 每个片区(多个分片) —> 每个分片(多个实体) 实体: 分片管理的 A ...
- ZIP:ZipEntry
ZipEntry: /* 此类用于表示 ZIP 文件条目. */ ZipEntry(String name) :使用指定名称创建新的 ZIP 条目. ZipEntry(ZipEntry e) :使用从 ...
- SP1805 HISTOGRA - Largest Rectangle in a Histogram 题解
题目链接:https://www.luogu.org/problemnew/show/SP1805 分析: 我们可以用一个单调栈由低到高来存储它的高度,并用数组对每个高度记录一下它前面(包括它自己)一 ...
- Jmeter(1):使用TCP取样器与socket接口进行简单通信
一个小任务:服务器与客户端连接,每次发送50个随机生成的字符,两秒发送一次 失败过太多次,然后昨晚终于跑通了,心情激动,于是清均第一篇博客就诞生了. 之前不了解jmeter,想过单纯用java编写服务 ...
- C#3.0新增功能10 表达式树 07 翻译(转换)表达式
连载目录 [已更新最新开发文章,点击查看详细] 本篇将介绍如何访问表达式树中的每个节点,同时生成该表达式树的已修改副本. 以下是在两个重要方案中将使用的技巧. 第一种是了解表达式树表示的算法,以 ...
- [PTA] 数据结构与算法题目集 6-8 求二叉树高度 & 6-9 二叉树的遍历
6.8 二叉树高度 int GetHeight(BinTree BT) { if (BT == NULL) return 0; int leftH = GetHeight(BT->Left); ...
- 盘一盘 synchronized (二)—— 偏向锁批量重偏向与批量撤销
在本文讲解之前,先来简单了解一下为什么会有批量重偏向和批量撤销. 批量重偏向:当一个线程创建了大量对象并执行了初始的同步操作,后来另一个线程也来将这些对象作为锁对象进行操作,会导偏向锁重偏向的操作 ...
- 织梦(dede)底层模板概念、常用底层模板字段
织梦(dede)底层模板概念.常用底层模板字段 一.底层模板的概念以及调用方式: 1. 什么是底层模板? 底层模板不是一个模板! 他就是在实际页面当中所要显示的具体内容: 2. 底层模板的应用: 调用 ...
- linux初学者-磁盘阵列篇
linux初学者-磁盘阵列篇 在磁盘的使用中,有时候需要提高磁盘的读写数据速度,就要用到磁盘组——raid,也就是磁盘阵列. 磁盘阵列是由最少两块以上的磁盘组成的,raid有许多模式,在这里将介绍其中 ...
- TestNG中@Factory的用法一:简单的数据驱动
为什么要使用@Factory注解呢,先来看下面这个例子 被测试类Person package ngtest; import org.testng.annotations.Parameters; imp ...
akka 集群 Sharding分片 分片上下级结构 集群(多台节点机) —> 每台节点机(1个片区) —> 每个片区(多个分片) —> 每个分片(多个实体) 实体: 分片管理的 A ...
ZipEntry: /* 此类用于表示 ZIP 文件条目. */ ZipEntry(String name) :使用指定名称创建新的 ZIP 条目. ZipEntry(ZipEntry e) :使用从 ...
题目链接:https://www.luogu.org/problemnew/show/SP1805 分析: 我们可以用一个单调栈由低到高来存储它的高度,并用数组对每个高度记录一下它前面(包括它自己)一 ...
一个小任务:服务器与客户端连接,每次发送50个随机生成的字符,两秒发送一次 失败过太多次,然后昨晚终于跑通了,心情激动,于是清均第一篇博客就诞生了. 之前不了解jmeter,想过单纯用java编写服务 ...
连载目录 [已更新最新开发文章,点击查看详细] 本篇将介绍如何访问表达式树中的每个节点,同时生成该表达式树的已修改副本. 以下是在两个重要方案中将使用的技巧. 第一种是了解表达式树表示的算法,以 ...
6.8 二叉树高度 int GetHeight(BinTree BT) { if (BT == NULL) return 0; int leftH = GetHeight(BT->Left); ...
在本文讲解之前,先来简单了解一下为什么会有批量重偏向和批量撤销. 批量重偏向:当一个线程创建了大量对象并执行了初始的同步操作,后来另一个线程也来将这些对象作为锁对象进行操作,会导偏向锁重偏向的操作 ...
织梦(dede)底层模板概念.常用底层模板字段 一.底层模板的概念以及调用方式: 1. 什么是底层模板? 底层模板不是一个模板! 他就是在实际页面当中所要显示的具体内容: 2. 底层模板的应用: 调用 ...
linux初学者-磁盘阵列篇 在磁盘的使用中,有时候需要提高磁盘的读写数据速度,就要用到磁盘组——raid,也就是磁盘阵列. 磁盘阵列是由最少两块以上的磁盘组成的,raid有许多模式,在这里将介绍其中 ...
为什么要使用@Factory注解呢,先来看下面这个例子 被测试类Person package ngtest; import org.testng.annotations.Parameters; imp ...