python的程序异常类型,Python3.4学习笔记之类型判断,异常处理,终止程序操作小结...

本文实例讲述了Python3.4类型判断,异常处理,终止程序操作。分享给大家供大家参考,具体如下:

python3.4学习笔记 类型判断,异常处理,终止程序,实例代码:

#idle中按F5可以运行代码

#引入外部模块 import xxx

#random模块,randint(开始数,结束数) 产生整数随机数

import random

import sys

import os

secret = random.randint(1,10)

temp = input("请输入一个数字\n")

#print(type(temp))# 类型判断

#print(isinstance(temp,int))#False

#异常处理 try except finally 没有catch函数

try:

guess = int(temp)

except:

print("输入的不是数字,程序终止了")#注释内容不能在逻辑代码块里独立一行进行

os._exit(0)#os._exit() 用于在线程中退出,sys.exit()用于在主线程中退出,exit(0)#终止退出程序,会关闭窗口

count = 0;

while guess != secret: #猜错的时候才进入循环条件

if count == 0 and guess > secret:

print("猜大了")

if count == 0 and guess < secret:

print("猜小了")

temp = input("请重新输入数字\n") #需要在判断之前让用户输入,否则猜对了就直接退出了

try:

guess = int(temp)

except (ZeroDivisionError,Exception):

print("输入的不是数字,请重新输入")

print(ZeroDivisionError,":",Exception)

count += 1 #不能使用count++这种方式

if count > 2:

print("猜错4次自动退出了")

break #退出循环

if guess == secret:

print("恭喜,你猜对了")

print("猜对了也就那样")

else:

if guess > secret:

print("猜大了")

else:

print("猜小了")

print("游戏结束")

运行结果:

请输入一个数字

2

猜小了

请重新输入数字

fads

输入的不是数字,请重新输入

:

猜小了

请重新输入数字

Python os._exit() sys.exit() exit()区别

Python退出程序的方式有两种:os._exit(), sys.exit()

1)os._exit() 直接退出 Python程序,其后的代码也不会继续执行。

2)sys.exit() 引发一个 SystemExit异常,若没有捕获这个异常,Python解释器会直接退出;捕获这个异常可以做一些额外的清理工作。

0为正常退出,其他数值(1-127)为不正常,可抛异常事件供捕获。

exit() 跟 C 语言等其他语言的 exit() 应该是一样的。

os._exit() 调用 C 语言的 _exit() 函数。

__builtin__.exit 是一个 Quitter 对象,这个对象的 __call__ 方法会抛出一个 SystemExit异常。

一般来说os._exit() 用于在线程中退出

sys.exit() 用于在主线程中退出。

import os

os._exit(0)

不能直接使用return

python注释内容不能在逻辑代码块里独立一行进行,空格和tab键都是有意义的

if try 等模块下面不能一行内容都没有,编译会认为逻辑有问题报错。

python中try except处理程序异常的三种常用方法

方法一:捕获所有异常

try:

a=b

b=c

except (ZeroDivisionError,Exception):

print(ZeroDivisionError,":",Exception)

方法二:采用traceback模块查看异常

#引入python中的traceback模块,跟踪错误

import traceback

try:

a=b

b=c

except:

traceback.print_exc()

方法三:采用sys模块回溯最后的异常

#引入sys模块

import sys

try:

a=b

b=c

except:

info=sys.exc_info()

print info[0],":",info[1]

但是,如果你还想把这些异常保存到一个日志文件中,来分析这些异常,那么请看下面的方法:

把 traceback.print_exc() 打印在屏幕上的信息保存到一个文本文件中

import traceback

try:

a=b

b=c

except:

f=open("c:log.txt",'a')

traceback.print_exc(file=f)

f.flush()

f.close()

import traceback

#断言assert关键字,程序自动崩溃并抛出AssertionError异常,用在重新中植入检查点

assert 4 > 3 #条件正确自动忽略跳过

print("pass...")

try:

assert 3 > 4

except (AssertionError):

traceback.print_exc()

print("after assert...")

输出结果:

pass...

Traceback (most recent call last):

File "F:/kanbox/pythoncode/if_for.py", line 28, in

assert 3 > 4

AssertionError

after assert...

希望本文所述对大家Python程序设计有所帮助。 ad51e517755f8fd6a7ec83ced4ecfaf3.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值