一内容回顾

  try/except

  try/except/else

  try/finally

  try/except

  try/except/finally

  try/except/else/finally

报错的时候

  1检查程序逻辑是不是有问题

  2.逻辑没有问题,但是就是会报错

    找到具体错误的那一行代码

    在这一行代码上加上try,再根据错误类型进行处理

主动抛异常

  raise 异常类型

自定义异常

  继承BaseException

  __str__方法的返回值就是这个异常抛出之后的异常内容

断言 assert语法,不满足条件就报错

hasblib模块

摘要模块:各种各样的摘要算法

md5/sha1

两件事:

  1.密码的密文存储: 各种算法 动态加盐

  2.文件的一致性校验

md5_obj =hashlib.md5(bytes 盐)# 创建一个新的md5值计算的对象

md5_obj.update(bytes) #每一次uodate,相当于在原来的字符串后面加上新的字符串

md5_obj.hexdigest() #只是获取最终结果

二今日内容

logging #日志模块

  给用户看 : 银行流水\购物记录

  哪一个管理员什么时候登陆 删除了一个学生

给程序员看的 :

  计算器 'asjkdghlghljgjl;;' 计算错误了

   录下每一个用户让你计算的表达式

   记录下每一个计算的步骤是怎么错的

# f = open()
# f.write('年月日时分秒 所在的文件 错误的级别 asjhkhkaghkldgh')
# f.close()
# 格式不好看 logging模块 这些格式你就不需要反复写
# 每一次都需要自己打开文件\关闭文件 logging就不需要了
# 有一些信息 能够控制它在某一写特定的时刻就打印出来
# logging模块不能自动帮助你生成日志,仍然是你自己写你想写的内容
# logging只是帮助你 简化操作文件的步骤\按照你的要求规划日志等级\帮助你规范格式
import logging
# logging.basicConfig(level=logging.DEBUG)
# logging.debug('debug message') # 最细节的 计算机计算的那些小过程
# logging.info('info message') # 普通信息 记录每个用户的操作
# logging.warning('warning message')# 警告信息 你觉得可能会影响到你程序的安全\正确率的内容
# logging.error('error message') # 错误信息 直接影响你程序的健康了
# logging.critical('critical message')#批判的 把整个userinfo文件删掉了
# 默认显示warning以上的日志
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S',
filename = 'test.log',
filemode = 'a'
# 1.操作系统的编码可能会出现乱码问题 
# 2.不支持同时向文件和屏幕输出
import logging
#logger对象的方式: 灵活性 可扩展性
logger = logging.getLogger() #创建一个logger对象
logger.setLevel(logging.DEBUG)
#创建一个文件操作符 来准备操作日志向文件中写这件事
fh = logging.FileHandler('mylog.log',encoding='utf-8')
fh2 = logging.FileHandler('mylog2.log',encoding='utf-8')
#创建一个屏幕操作符,来准备操作日志向屏幕中写这件事
sh = logging.StreamHandler()
#创建一个输出格式
formatter = logging.Formatter('%(asctime)s%(filename)s[line:%(lineno)d]%(levelname)s %(message)s')
formatter2 = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')

#组合
#输出格式和文件操作符\屏幕操作符绑在一起
fh.setFormatter(formatter)
sh.setFormatter(formatter2)
sh.setLevel(logging.ERROR)
# logger对象分别和文件操作符\屏幕操作符绑在一起
logger.addHandler(fh)
logger.addHandler(fh2)
logger.addHandler(sh)

#才开始能够使用logger来记录日志
logger.debug('debug message')
logger.info('info message')
logger.warning('warning message')
logger.error('error message')
logger.critical('critical message')

三.模块

# mymodule就是模块
# import mymodule mymodule就是一个变量了
# 导入一个模块相当于什么???
# 执行了这个模块对应的文件
# 并且在执行的过程中 所有的函数名\变量名\类名都会绑定在这个模块中
# 1.开辟了一块属于这个模块的空间
# 2.让这个导入的名字mymodule指向这个空间
# 3.执行模块中的代码,把所有的名字都存储在这个空间中
# 模块会被重复导入么?不会
# import mymodule as m
# print(m.name)
# m.read1()
# as语句的用法
# 1.名字很长的时候
# 2.相同功能名字不同的几个模块的兼容问题
# from mymodule import name,read2
# from import 这个语法一旦执行,相当于什么?
# from import 仍然相当于执行整个文件
# 在from import 的过程中发生了什么事情?
# 1.创建一个空间
# 2.执行模块的代码 并且把每一个变量都放在空间中
# 3.创建变量名 = import的名字,并且指向空间中对应的变量
# 注意 :
# 在写代码的过程中,不要取和导入的变量名相同的名字,否则会导致导入的名字不可用
#模块中的变量永远是独立的,在内部是独立的使用的
 

day33 Pyhton logging 模块和包的更多相关文章

  1. day33 Pyhton 常用模块03

    一.正则表达式: 1.元字符 . 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线 \s 匹配任意的空白符 \d 匹配数字 \n 匹配一个换行符 \t 匹配一个制表符 \b 匹配一个单词的结尾 ...

  2. day18包的使用与日志(logging)模块

    包的使用与日志(logging)模块1. 什么是包    包就是一个包含有__init__.py文件的文件夹    包本质就是一种模块,即包是用包导入使用的,包内部包含的文件也都是用来被导入使用2 为 ...

  3. 18 包 ,logging模块使用

    包: 1 什么是包: 包就是一个包含有__init__.py文件的文件夹 宝本质就是一种模块,即包就是用包导入使用的,包内部包含的文件也都是用来被导入使用 2 为什么要用包 包就是文件夹,那文件加就是 ...

  4. python基础之包与logging模块

    包 1.什么是包? 包是模块的一种形式,包的本质就是一个含有__init__.py文件的文件夹 2.为什么要有包? 提高程序的结构性和可维护性 3.如何使用包? 导入包就是在导包下的__init__. ...

  5. 7.19 包 logging模块 hashlib模块 openpyxl模块 深浅拷贝

    包 包是什么 他是一系列文件的结合体,表现形式就是文件夹 包的本质还是模块 他通常会有__init__.py文件 我们首先回顾一下模块导入的过程 import module首次导入模块(.py文件) ...

  6. day17_7.19包与logging模块,深浅拷贝

    一.包 在模块的定义里,模块就是方法的集合,可以将一些常用的方法封装到一个py文件中,通过调用使用,而且,其中的表现形式也有以包的形式导入. 其实,包就是一系列模块的结合体,表示形式就是一个文件夹,在 ...

  7. 2019-7-19 包、logging模块、hashlib(加密模块)、openpyxl模块、深浅拷贝

    一.包 什么是包: 它是一系列模块文件的结合体,表示形式就是一个文件夹.该文件内部通常会有一个__init__.py文件,包的本质还是一个模块,可以被调用,调包就相当于与调用__init__.py文件 ...

  8. Python进阶(十一)----包,logging模块

    Python进阶(十一)----包,logging模块 一丶包的使用 什么是包: ​ 包是通过使用 .模块名的方式组织python模块名称空间的方式. 通俗来说,含有一个__init__.py文件的文 ...

  9. 17.Python略有小成(包,logging模块)

    Python(包,logging模块) 一.包 什么是包 官网解释 : 包是一种通过使用'.模块名'来组织python模块名称空间的方式 , 具体来讲 , 包就是一个包含有__ init __.py文 ...

随机推荐

  1. Oracle自动存储管理ASM

    参考资料: https://docs.oracle.com/cd/B19306_01/server.102/b14231/storeman.htm#ADMIN036 什么是ASM? ASM是Autom ...

  2. 分布式处理框架Hadoop的安装与使用

    Hadoop简介 Hadoop是一个由Apache基金会所开发的分布式系统基础架构.用户可以在不了解分布式底层细节的情况下,开发分布式程序. 充分利用集群的威力进行高速运算和存储.Hadoop实现了一 ...

  3. 【Flutter 实战】菜单(Menu)功能

    老孟导读:今天介绍下Flutter中的菜单功能. PopupMenuButton 使用PopupMenuButton,点击时弹出菜单,用法如下: PopupMenuButton<String&g ...

  4. tsconfig.json无法写入webpack.config.js 因为它会覆盖输入文件。

    这个错误是什么意思?为什么要写入这个文件?即使我将该文件从项目中排除,该错误仍然存​​在.我该如何纠正这一点? 我将webpack.config.js文件删除,问题仍然存在. 解决方法: 如果未指定e ...

  5. 渗透测试方法论(qf总结)

    渗透测试(penetration testing , pentest)是实施安全评估(即审计)的具体手段.方法论是在指定.实施信息安全审计方案时,需要遵循的规则.惯例和过程.人们在评估网路.应用.系统 ...

  6. 基础篇:JAVA内部类的使用介绍

    目录 1 四种内部类 2 内部类的使用场景和优点 3 成员内部类 4 成员内部类的访问范围详解 5 静态内部类 6 局部内部类 7 匿名内部类 欢迎指正文中错误 关注公众号,一起交流 参考文章 1 四 ...

  7. 自定义springboot - starter 实现日志打印,并支持动态可插拔

    1. starter 命名规则: springboot项目有很多专一功能的starter组件,命名都是spring-boot-starter-xx,如spring-boot-starter-loggi ...

  8. Tomcat学习小记(二)

    1.Tomcat源码入口 生命周期统一管理接口:LifeCycle 实现LifeCycle接口的类:(idea快捷键:Ctrl+h) 多个组件共同实现LifeCycle接口 Tomcat启动入口分析: ...

  9. Python-IndentationError: expected an indented block

    Error: IndentationError: expected an indented block Where? Python代码执行时候报这个错误 Why? Python代码具有严格缩进规范,默 ...

  10. Centos-切换用户身份-su

    su 切换用户身份 相关选项 - 加载相应用户下环境变量 -c   使用某个身份执行一个指令 -m  改变用户身份不改变环境变量 切换为超级用户 su - 普通用户切换为超级用户需要输入密码,超级用户 ...