1、try except

num = input('num : ')
#try在阶段中处理异常
try:
f = open('file', 'w')
int(num)
except ValueError: #发现这个异常不会报错只会输出后面的代码
print('请输入一个数字') '''
输出结果:
num : ss
请输入一个数字
'''

2、万能异常

num = input('num : ')
#
try:
f = open('file', 'w')
int(num)
except : #万能异常
print('异常啦')
'''
输出结果: num : ss
异常啦 '''
#这样抛异常非常不礼貌因为你无法分析是哪里出问题了 num = input('num : ')
#
try:
f = open('file', 'w')
int(num)
except Exception as e: #万能异常 #这样抛异常更加好能让人分析是什么问题
print(e,'异常啦') '''
输出结果:
num : ss
invalid literal for int() with base 10: 'ss' 异常啦 ''' num = input('num : ')
#当在这一块代码块这里可能出现的问题千奇百怪,去解决你想不到的具体的错误的时候
try: f = open('file', 'w') int(num) except ValueError: print('请输入一个数字') except Exception as e: #万能异常
# 
 print('异常啦') ''' 输出结果: num : ss 请输入一个数字 ''' 组合异常 

3、else

num = input('num : ')
#
try:
f = open('file', 'w')
int(num)
except ValueError:
print('请输入一个数字')
except Exception as e: #万能异常
print('异常啦')
else:
print('else 被执行') #当前面代码没有出现异常时会执行者这个
'''
输出结果:
num : 1
else 被执行
'''

4、finally

num = input('num : ')
#
try:
f = open('file', 'w')
int(num)
except ValueError:
print('请输入一个数字')
except Exception as e: #万能异常
print('异常啦')
else:
print('else 被执行')
finally: #当遇见必须要执行的代码就用finally
print('finally')
'''
num : s
请输入一个数字
finally
'''

5、断言

assert 2==1   断言一个会抛出异常的判断

6、总结

# # strat.py
# def main():pass # try:
# pass
# except ValueError:
# pass
# except Exception as e:
# print('统筹处理所有错误的措施')
# else:
# print("针对这段try中的代码没有异常要特别处理的")
# finally:
# print("不管有没有异常都要执行的代码")
#
#
# assert 1 == 2 #认识 #什么时候用异常处理:你能想到有异常,并且可能出现在这一块代码的异常有很多种,不能一一枚举
#禁止在大段代码外面套异常处理

补充模块

1、hashlib

# 文件校验
# 文件是否被改变
# 登录密码
#不能解密,但可以“撞库”
#加盐 hashlib.md5('nezha'.encode('utf-8')) # user = 'alex'
# pwd = '3713'
# md5_obj = hashlib.md5(user.encode('utf-8'))
# md5_obj.update(pwd.encode('utf-8'))
# print(md5_obj.hexdigest()) #加密 '''
输出结果:
06516a702c45b79e2e31aaf047d3863b
'''
user='alex'
pwd=''
md5_obj =hashlib.md5(user.encode('utf-8'))
md5_obj.update(''.encode('utf-8'))
s=md5_obj.hexdigest() #进行密码加密 name=input('请输入用户名:')
password=input('请输入密码: ')
md5_obj =hashlib.md5(name.encode('utf-8')) #当用户输入用户名和密码在加密一次然后进行判断
md5_obj.update(password.encode('utf-8'))
ss=md5_obj.hexdigest()
if ss ==s :
print('登陆成功 ')
else:
print("登陆失败")

用法

2、import configparser

生成配置文件

增删改操作

import configparser

config = configparser.ConfigParser()      #实例化

config["DEFAULT"] = {'ServerAliveInterval': '',
'Compression': 'yes',
'CompressionLevel': '',
'ForwardX11':'yes'
} config['bitbucket.org'] = {'User':'hg'} config['topsecret.server.com'] = {'Host Port':'','ForwardX11':'no'} with open('example.ini', 'w') as configfile: #然后把生成的内容保存到文件中 config.write(configfile)

生成配置文件

import configparser

config = configparser.ConfigParser()
s=config.read('example.ini')
print(config['DEFAULT']['Compression']) '''
输出结果:
yes
'''
import configparser
config = configparser.ConfigParser()
s=config.read('example.ini')
#
config.add_section('yuan') #添加了组yuan
with open('example.ini', 'w') as configfile:
config.write(configfile) #example.ini 文件内容
[DEFAULT]
serveraliveinterval = 45
compression = yes
compressionlevel = 9
forwardx11 = yes [topsecret.server.com]
host port = 50022 [yuan] #可以看到已经添加了

 3、loggin模块

import logging
def my_logger(filename,file=True,stream = True):
logger = logging.getLogger()
formatter = logging.Formatter(fmt='%(name)s %(asctime)s [%(lineno)d] -- %(message)s',
datefmt='%d/%m/%y %H:%M:%S')
logger.setLevel(logging.DEBUG) #指定日志打印的等级
if file:
file_handler = logging.FileHandler(filename,encoding='utf-8')
file_handler.setFormatter(formatter) # 文件流 文件操作符
logger.addHandler(file_handler)
if stream:
stream_handler = logging.StreamHandler()
stream_handler.setFormatter(formatter) #屏幕流 屏幕操作符
logger.addHandler(stream_handler)
return logger logger = my_logger('logging')
logger.warning("出错了")
logger.debug("debug")
import logging
logging.debug('debug message')
logging.info('info message')
logging.warning('warning message')
logging.error('error message')
logging.critical('critical message')

默认情况下Python的logging模块将日志打印到了标准输出中,且只显示了大于等于WARNING级别的日志,这说明默认的日志级别设置为WARNING(日志级别等级CRITICAL > ERROR > WARNING > INFO > DEBUG),默认的日志格式为日志级别:Logger名称:用户输出消息。

灵活配置日志级别,日志格式,输出位置:

配置参数

logging.basicConfig()函数中可通过具体参数来更改logging模块默认行为,可用参数有:

filename:用指定的文件名创建FiledHandler,这样日志会被存储在指定的文件中。
filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
format:指定handler使用的日志显示格式。
datefmt:指定日期时间格式。
level:设置rootlogger(后边会讲解具体概念)的日志级别
stream:用指定的stream创建StreamHandler。可以指定输出到sys.stderr,sys.stdout或者文件(f=open(‘test.log’,’w’)),默认为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略。 format参数中可能用到的格式化串:
%(name)s Logger的名字
%(levelno)s 数字形式的日志级别
%(levelname)s 文本形式的日志级别
%(pathname)s 调用日志输出函数的模块的完整路径名,可能没有
%(filename)s 调用日志输出函数的模块的文件名
%(module)s 调用日志输出函数的模块名
%(funcName)s 调用日志输出函数的函数名
%(lineno)d 调用日志输出函数的语句所在的代码行
%(created)f 当前时间,用UNIX标准的表示时间的浮 点数表示
%(relativeCreated)d 输出日志信息时的,自Logger创建以 来的毫秒数
%(asctime)s 字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
%(thread)d 线程ID。可能没有
%(threadName)s 线程名。可能没有
%(process)d 进程ID。可能没有
%(message)s用户输出的消息

python全栈开发从入门到放弃之异常处理的更多相关文章

  1. python全栈开发从入门到放弃之迭代器生成器

    1.python中的for循环 l = [1,2,3,4,5,6] for i in l: #根据索引取值 print(i) 输出结果: 1 2 3 4 5 6 2.iterable  可迭代的 可迭 ...

  2. python全栈开发从入门到放弃之socket网络编程基础

    网络编程基础 一 客户端/服务器架构 1.硬件C/S架构(打印机) 2.软件C/S架构 互联网中处处是C/S架构 如黄色网站是服务端,你的浏览器是客户端(B/S架构也是C/S架构的一种) 腾讯作为服务 ...

  3. python全栈开发从入门到放弃之递归函数的调用

    1.递归效率低,需要在进入下一次递归时保留当前的状态,见51cto博客 解决方法是尾递归,即在函数的最后一步(而非最后一行)调用自动但是python又没有尾递归,且对递归层级做了限制 必须有一个明确的 ...

  4. python全栈开发从入门到放弃之初识面向对象

    面向过程 VS 面向对象 面向过程的程序设计的核心是过程(流水线式思维),过程即解决问题的步骤,面向过程的设计就好比精心设计好一条流水线,考虑周全什么时候处理什么东西. 优点是:极大的降低了写程序的复 ...

  5. python全栈开发从入门到放弃之面向对象的三大特性

    组合 class Course: def __init__(self,name,period,price): self.name = name self.period = period self.pr ...

  6. python全栈开发从入门到放弃之socket并发编程多进程

    1.1 multiprocessing模块介绍 python中的多线程无法利用多核优势,如果想要充分地使用多核CPU的资源(os.cpu_count()查看),在python中大部分情况需要使用多进程 ...

  7. python全栈开发从入门到放弃之socket并发编程多线程

    一 threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性,因而不再详细介绍 二 开启线程的两种方式 from threadi ...

  8. python全栈开发从入门到放弃之socket并发编程之协程

    一.为什么会有协程 本节的主题是基于单线程来实现并发,即只用一个主线程(很明显可利用的cpu只有一个)情况下实现并发,为此我们需要先回顾下并发的本质:切换+保存状态 cpu正在运行一个任务,会在两种情 ...

  9. python全栈开发从入门到放弃之网络基础

    一.操作系统基础 操作系统:(Operating System,简称OS)是管理和控制计算机硬件与软件资源的计算机程序,是直接运行在“裸机”上的最基本的系统软件,任何其他软件都必须在操作系统的支持下才 ...

随机推荐

  1. 【基础练习】【BFS+A*】codevs1225八数码难题题解

    题目描写叙述 Description Yours和zero在研究A*启示式算法.拿到一道经典的A*问题,可是他们不会做,请你帮他们. 问题描写叙述 在3×3的棋盘上,摆有八个棋子,每一个棋子上标有1至 ...

  2. H&M

    H&M于1947年由Erling Persson在瑞典创立.如今,H&M在全世界1500 多个专卖店销售服装.配饰与化妆品.位于瑞典市Stora Gatan大街的老H&M店是世 ...

  3. hdu 2612:Find a way(经典BFS广搜题)

    Find a way Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  4. springmvc+mybatis+maven项目框架搭建

    项目的目录

  5. sql语句优化 (转)

    性能不理想的系统中除了一部分是因为应用程序的负载确实超过了服务器的实际处理能力外,更多的是因为系统存在大量的SQL语句需要优化. 为了获得稳定的执行性能,SQL语句越简单越好.对复杂的SQL语句,要设 ...

  6. cxGrid 锁定列

    cxGrid锁定列 第1步: 双击cxGrid -> 点击页签“Bands”->点击“Add”加入2个tcxGridBrand, 将1个锁定在左边,最后一个锁定在右边. 如下图 第2步: ...

  7. Linux内核态、用户态简介与IntelCPU特权级别--Ring0-3

    一.现代操作系统的权限分离: 现代操作系统一般都至少分为内核态和用户态.一般应用程序通常运行于用户态,而当应用程序调用系统调用时候会执行内核代码,此时会处于内核态.一般的,应用程序是不能随便进入内核态 ...

  8. 170324、Spring 处理器和Resource

    1.Spring 框架允许开发者使用两种后处理器扩展 IoC 容器,这两种后处理器扩展 IoC 容器,这两种后处理器可以后处理 IoC 容器本身,或对容器中所有的 Bean 进行后处理.IoC 容器还 ...

  9. java发展历程、常用dos命令与jDK工具使用

    Java菜鸟学习之旅 1.勤敲代码 2.必须将课堂上讲的内容学到位 2.1 学到会用 2.2 在学会之前不要自作主张 2.3 当天课程当天完成 3.能说会道 3.1 善于表达 3.2 学会的都能讲 4 ...

  10. Python--进阶处理8

    # ====================第八章:类与对象========================= # --------------改变对象的字符串显示------------------ ...