6.Python学习:异常和日志

1.异常的抓取

1.1异常的概念

在这里插入图片描述

  • 使用异常前:
print(1/0)

在这里插入图片描述

  • 使用异常后:错误提示更加友好,不影响程序继续往下运行
try:print(10/0)
except ZeroDivisionError:print("0不能作为分母")

在这里插入图片描述

1.2异常的抓取

第一种:如果提前知道可能会抛出哪些异常,可以直接写出要抓取的异常名称

try:number1=int(input("请输入一个整数:"))print(1 / number1)
except ZeroDivisionError:print("0不能作为分母")
except ValueError:print("您输入的不是整数")
except://不知道还会出现哪些异常时,可以抓取任何异常进行兜底print("程序出现异常")

第二种:抓取任何异常

try:number1=int(input("请输入一个整数:"))print(1/number1)
except Exception as e:print(e)

2.else与finally-都只出现一次

else:没有出现异常会执行
finally:不管有没有异常都会执行

try:number1=int(input("请输入一个整数:"))print(1/number1)
except Exception as e:print(e)
else:print("程序运行完毕,未出现异常")
finally:print("程序执行完毕")

在这里插入图片描述

3.常见的异常

所有的异常,都是Exception的子类或者子类的子类

print(NameError.__base__)# <class 'Exception'>
print(IndexError.__base__.__base__)# <class 'Exception'>
print(FileNotFoundError.__base__.__base__)# <class 'Exception'>

自定义异常类,继承Exception类

  • NameError,变量没有定义直接使用
  • IndexError下标越界
  • FileNotFoundError找不到文件,路径不对

4.手动抛出异常

在这里插入图片描述

try:raise IOError
except IOError:print("出现IO异常")

4.loguru日志模块

(1)工作中通常将将异常写入日志中
(2)loguru是一个python 第三方库,是较为常用的日志模块
pip install loguru -i https://pypi.tuna.tsinghua.edu.cn/simple/ --trusted-host pypi.tuna.tsinghua.edu.cn
from loguru import logger

5.日志的级别

  • debug<info<warning<error<critical(崩溃,致命)
  • 不同级别日志,颜色不同
from loguru import logger
# 日志级别
logger.debug('log')
logger.info('log')
logger.warning('log')
logger.error('log')
logger.critical('log')

在这里插入图片描述

6.logger.add()

loguru模块可以配置各种参数
在这里插入图片描述

import os
if not os.path.exists('./log'):#如果当前路径下没有log目录,则新建os.mkdir('./log')
logger.remove(handler_id=None)#不在控制台打印
logger.add('./log/log1.log',rotation='200KB',compression='zip',encoding='utf-8')for i in range(10000):logger.warning('===warning.log===')

在这里插入图片描述
logger里边写入异常信息:

import os
if not os.path.exists('./log'):#如果当前路径下没有log目录,则新建os.mkdir('./log')
logger.remove(handler_id=None)#不在控制台打印
logger.add('./log/log1.log',rotation='200KB',compression='zip',encoding='utf-8')
try:number1=int(input("请输入一个整数:"))print(1 / number1)
except ZeroDivisionError as e1:logger.error("0不能作为分母")
except ValueError as e2:logger.error("您输入的不是整数")
except Exception as e3:logger.error("程序出现异常0")

在这里插入图片描述

7.

handle_loguru.py
在这里插入图片描述
在这里插入图片描述
只记level=error以上的日志,error,critical
在这里插入图片描述

handle_path.py
在这里插入图片描述
loguru.ini
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/43782.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2020 ICPC Shanghai Site B. Mine Sweeper II 题解 构造 鸽巢原理

Mine Sweeper II 题目描述 A mine-sweeper map X X X can be expressed as an n m n\times m nm grid. Each cell of the grid is either a mine cell or a non-mine cell. A mine cell has no number on it. Each non-mine cell has a number representing the number of…

Spring Boot使用@RestController注解的控制器(Controller)返回Map时,遇到序列化问题

在Spring Boot中使用RestController注解的控制器&#xff08;Controller&#xff09;返回Map时&#xff0c;如果遇到序列化问题&#xff0c;这通常是因为Map中的某些值类型无法被Spring Boot默认的JSON序列化库&#xff08;通常是Jackson&#xff09;正确处理。以下是一些可能导…

遍历请求后端数据引出的数组forEach异步操作的坑

有一个列表数据&#xff0c;每项数据里有一个额外的字段需要去调另外一个接口才能拿到&#xff0c;后端有现有的这2个接口&#xff0c;现在临时需要前端显示出来&#xff0c;所以这里需要前端先去调列表数据的接口拿到列表数据&#xff0c;然后再遍历请求另外一个接口去拿到对应…

【python技巧】pytorch网络可视化

参考 https://blog.csdn.net/qq_40726937/article/details/106122082 1. graphviz torchviz 环境安装简单 pip install torchviz pip install graphviz代码 import torch from torchvision import model from torchviz import make_dotmodels models.resnet18() x torc…

生产环境中秒杀接口并发量剧增与负载优化策略探讨

✨✨谢谢大家捧场&#xff0c;祝屏幕前的小伙伴们每天都有好运相伴左右&#xff0c;一定要天天开心哦&#xff01;✨✨ &#x1f388;&#x1f388;作者主页&#xff1a; 喔的嘛呀&#x1f388;&#x1f388; 目录 引言 1. 实施限流措施 1.1 令牌桶算法&#xff1a; 1.2 漏…

红酒知识百科:从入门到精通

红酒&#xff0c;这个深邃而迷人的世界&#xff0c;充满了无尽的知识与奥秘。从葡萄的选择、酿造工艺&#xff0c;到品鉴技巧&#xff0c;每一步都蕴藏着深厚的文化底蕴和精细的技艺。今天&#xff0c;就让我们一起踏上这场红酒知识之旅&#xff0c;从入门开始&#xff0c;逐步…

gpt-4o看图说话-根据图片回答问题

问题&#xff1a;中国的人口老龄化究竟有多严重&#xff1f; 代码下实现如下&#xff1a;&#xff08;直接调用openai的chat接口&#xff09; import os import base64 import requests def encode_image(image_path): """ 对图片文件进行 Base64 编码 输入…

【刷题汇总 -- 求最小公倍数、数组中的最长连续子序列、字母收集】

C日常刷题积累 今日刷题汇总 - day0081、求最小公倍数1.1、题目1.2、思路1.3、程序实现 -- 穷举法1.2、程序实现 -- 辗转相除法 2、数组中的最长连续子序列2.1、题目2.2、思路2.3、程序实现 3、字母收集3.1、题目3.2、思路3.3、程序实现 4、题目链接 今日刷题汇总 - day008 1、…

Windows C++ vs2022环境中下载、安装和使用osmesa

第一步&#xff1a;安装 MinGW-w64 请参考这篇文章进行安装&#xff1a; 在Windows中安装MinGW-w64最新版本 第二步&#xff1a;安装DirectX SDK 请参考这篇文章进行安装&#xff1a; 下载安装Microsoft DirectX SDK(June 2010) 第三步&#xff1a;安装Windows SDK 请参考这篇…

重定向(Redirect)和转发(Forward)

目录 重定向(Redirect) 转发(Forward) 在HTTP通信和Web开发中,重定向(Redirect)和转发(Forward)是两种常见的导航机制,它们各自具有不同的特点和适用场景。 forward是转发,foward url不会发生改变,forward可以共享request里的数据,forward 比 redirect 效率高。…

LeetCode 算法:课程表 c++

原题链接&#x1f517;&#xff1a;课程表 难度&#xff1a;中等⭐️⭐️ 题目 你这个学期必须选修 numCourses 门课程&#xff0c;记为 0 到 numCourses - 1 。 在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisites 给出&#xff0c;其中 prerequisites[i]…

oracle索引字段存储数据过长,导致索引失效

1&#xff1a;短位数据&#xff0c;索引生效 2&#xff1a;长位索引&#xff0c;索引不生效 此问题发现于6月中旬&#xff0c;线上问题优化。引以为戒。 解决&#xff1a; 并未解决索引不生效问题&#xff0c; 但是基于优化查询&#xff0c;是的查询保持毫秒级

第一个基于FISCOBCOS的前后端项目(发行转账)

本文旨在介绍一个简单的基于fiscobcos的前后端网站应用。Springbootjs前后端不分离。 所使用到的合约也是一个最基本的。首先您需要知道的是完整项目分为三部分&#xff0c;1是区块链平台webase搭建&#xff08;此项目使用节点前置webase-front即可&#xff09;&#xff0c;2是…

[stm32f407]GPIO配置方式

GPIO模式&#xff1a; GPIO_InitStructure.GPIO_ModeGPIO_Mode_IN;GPIO_InitStructure.GPIO_OTypeGPIO_OType_PP;//是否需要GPIO_InitStructure.GPIO_PinGPIO_Pin_11;GPIO_InitStructure.GPIO_PuPdGPIO_PuPd_UP;//上拉GPIO_InitStructure.GPIO_SpeedGPIO_Speed_50MHz; GPIO_Mo…

什么是防抖和节流?如何理解它们并在不同的场景条件下灵活运用?

&#x1f64b;‍♂️ 什么是防抖和节流&#xff1f; 防抖&#xff08;Debouncing&#xff09;和节流&#xff08;Throttling&#xff09;是两种常见的性能优化技术&#xff0c;常用于控制某些操作&#xff08;例如事件处理器&#xff09;的频率&#xff0c;从而减少资源消耗并…

Diffusion 公式推导 2

Diffusion 公式推导 中对 DDPM 进行了推导&#xff0c;本文接着对 DDIM 进行推导。 目录 六. 模型改进 六. 模型改进 从扩散模型的推理过程不难看出&#xff0c;DDPM 有一个致命缺点 —— 推理速度过慢&#xff0c;因为逆扩散是从 x T x_{T} xT​ 到 x 0 x_{0} x0​ 的完整过…

ubuntu 如何解压tar

在Ubuntu中解压.tar文件&#xff0c;可以使用tar命令。以下是解压.tar文件的命令&#xff1a; tar -xvf file.tar 解释&#xff1a; x 表示解压 v 表示显示过程中的详细信息&#xff08;可选&#xff09; f 表示后面跟文件名 这将在当前目录下解压file.tar文件的内容。如果…

语义分割和实例分割区别?

语义分割&#xff1a;将图像中的每个像素分配给其对应的语义类别&#xff0c;其主要针对于像素&#xff0c;或者说它是像素级别的图像分割方法。&#xff1a;语义分割的目的是为了从像素级别理解图像的内容&#xff0c;并为图像中的每个像素分配一个对象类。 实例分割&#xf…

【HarmonyOS NEXT】鸿蒙线程安全容器集collections.TypedArray

collections.TypedArray 一种线性数据结构&#xff0c;底层基于ArkTS ArrayBuffer实现。目前支持包括Int8Array、Uint8Array、Int16Array、Uint16Array、Int32Array以及Uint32Array。 文档中存在泛型的使用&#xff0c;涉及以下泛型标记符&#xff1a; TypedArray: 指上述6种…

Laravel Excel导出功能:高效实现数据导出

Laravel是一个功能丰富的PHP Web开发框架&#xff0c;它提供了许多内置功能来简化开发过程。其中&#xff0c;Laravel Excel导出功能是处理数据导出任务的强大工具。通过使用Maatwebsite的Laravel Excel包&#xff0c;开发者可以轻松地将数据集导出为Excel文件&#xff0c;这对…