python相关知识-logging日志、property属性、上下文管理器、生成器等

1.logging日志

目的:

1.可以很方便的了解程序的运行情况

2.可以分析用户的操作行为、喜好等信息

3.方便开发人员检查bug

级别介绍:

1.DEBUG:程序调试bug时使用

2.INFO:程序正常运行时使用

3.WARNNING:程序未按预期运行时使用,但并不是错误的。如用户登录密码错误

4.ERROR:程序出错误时使用,如:IO操作失败

5.CRITICAL:特别严重的问题,导致程序不能再继续运行时使用,如磁盘空间为空,一般很少使用

默认的是WARNNING等级,当在WARNNING或WARNNING之上等级的才记录日志信息

日志等级从低到高的顺序是:DEBUG<INFO<WARNNING<ERROR<CRITICAL

#设置logging日志的配置信息

#level表示设置级别

#%(asctime)s表示当前时间

#%(filename)s表示程序文件名

#%(lineno)d表示行号

#%(levelname)s表示日志级别

#%(message)s表示日志信息

logging.basicConfig(level=logging.DEBUG,

format="%(asctime)s-%(filename)s[lineno:%(lineno)d]-%(levelname)s-%(message)s",

filename="log.txt",

filemode="a")

 

logging.debug("我一个debug级别的日志信息111")

logging.info("我一个info级别的日志信息")

logging.warning("我一个warning级别的日志信息")

logging.error("我一个error级别的日志信息")

logging.critical("我一个critical级别的日志信息")

#默认是warning,只有大于等于warning级别的日志才会输出显示

2.property属性

就是负责把一个方法当作属性进行使用,这样可以简化代码使用

装饰器方式:

@property表示把方法当作属性使用,表示当获取属性时会执行下面修饰的方法

@方法名.setter表示把方法当做属性使用,表示当设置属性时会执行下面修饰的方法

装饰器方式的property属性修饰的方法名一定要一样

类属性方式:

3.with语句

with语句打开关闭文件即安全又简单,并且with语句执行完成用户自动调用关闭文件操作,即使出现异常也会自动调用关闭文件操作

with open("1.txt, "w") as f:

f. write("hello world")

with语句执行完成,关闭文件操作自动完成,即使出现异常也不影响

4.上下文管理器

一个类只要实现了__enter__( )和__exit__( )这两个方法,通过该类创建的对象我们就称为上下文管理器

__enter__( ):上文方法,负责返回操作对象资源,比如文件对象,数据库连接对象

__exit__( ):下文方法,负责释放资源,with语句完成后自动执行,比如关闭文件,关闭数据库连接对象

上下文管理器可以使用with语句,with语句之所以这么强大,背后是由上下文管理器做支撑的,也就是说,open函数创建的文件对象就是一个上下文管理器对象

另一种实现方式:

假如想让一个函数称为上下文管理器,python提供了一个@contextmanager的装饰器,更进一步简化了上下文管理器的实现方式。通过yield将函数分割成两部分,yield上面的语句在__enter__方法中执行,yield下面的语句在__exit__方法中执行,紧跟在yield后面的参数是函数的返回值

5.生成器

根据程序员指定的规则循环生成的数据,当条件不成立时则生成数据结束。数据不是一次性全部生成处理,而是使用一个,再生成一个,可以节约大量内存。

创建生成器的方式:

1.生成器推导式:

与列表推导式类似,只不过生成器推导式使用小括号

2.yield关键字

只要在def函数里看到有yield关键字就是生成器

使用场景:

例如斐波那契数列

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

学会python——读取大文本文件(python实例六)

目录 1、认识Python 2、环境与工具 2.1 python环境 2.2 Visual Studio Code编译 3、读取大文本文件 3.1 代码构思 3.2 代码示例 3.3 运行结果 4、总结 1、认识Python Python 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。 Python 的设计具有很强…

基于机器学习的变频器故障诊断方法(MATLAB,Python)

变频器故障数据由MATLAB Simulink生成。 import pandas as pd import numpy as np import matplotlib.pyplot as plt import seaborn as sns from sklearn.neighbors import KNeighborsClassifier from sklearn.svm import SVC from sklearn.ensemble import RandomForestClass…

UniVue更新日志:使用Carousel组件实现轮播图效果

github仓库 稳定版本仓库&#xff1a;https://github.com/Avalon712/UniVue 开发版本仓库&#xff1a;https://github.com/Avalon712/UniVue-Develop UniVue扩展框架-UniVue源生成器仓库&#xff1a;https://github.com/Avalon712/UniVue-SourceGenerator 更新说明 今天的更…

【面试干货】String、StringBuilder、StringBuffer 的区别

【面试干货】String、StringBuilder、StringBuffer 的区别 1、String2、StringBuffer3、StringBuilder4、性能对比5、使用建议 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在Java中&#xff0c;String、StringBuilder和StringBuffer是用…

是否要把展会客户引到国际站等付费平台?

有人问我&#xff1a;那些在展会来的客户&#xff0c;如果让我们发网站链接&#xff0c;是否要发公司的付费平台&#xff0c;比如阿里&#xff0c;中国制造网等&#xff1f; 我的建议是不要发&#xff0c;最好是发公司的官网链接。接着她说公司在付费平台上更新得比较频繁&…

湖北省小学毕业学籍照片采集流程及教师手机拍摄方法说明

随着教育信息化的不断推进&#xff0c;学籍管理也越来越规范和便捷。湖北省小学毕业学籍照片采集作为学籍管理的重要组成部分&#xff0c;对于确保学生信息的准确性和完整性具有重要意义。本文将详细介绍湖北省小学毕业学籍照片采集的流程&#xff0c;并提供教师使用手机拍摄照…

KKT基础知识

KKT条件定义 KKT条件(Karush–Kuhn–Tucker conditions)是最优化&#xff08;特别是非线性规划&#xff09;领域最重要的成果之一&#xff0c;是判断某点是极值点的必要条件。 最优化问题 要选择一组参数&#xff08;变量&#xff09;&#xff0c;在满足一定的限制条件&…

个人云服务器已经被安全合规等卡脖子 建议不要买 买了必定后悔 安全是个大问题 没有能力维护

我的想法 自己买一个云服务器&#xff0c;先自己边做边学习&#xff0c;向往硅谷精神&#xff0c;财富与自由。如果能赚钱&#xff0c;就开个公司。这次到期就放弃了。 我前前后后6年花6000多元买云服务器。业余花了无数的精力&#xff0c;从2018到现在 &#xff0c;也没有折…

【代码随想录——动态规划——第三周】

1.目标和 这里设置背包的最大长度为2100即可&#xff0c;因为题目中有说数组之和小于1000.但考虑到我们需要实行jnums[i]所以保守起见我们设置的数应该稍大于2000即可&#xff0c;这里我们设置为2100。 1.1 我的解法&#xff08;粗糙了&#xff09; func findTargetSumWays(n…

VMware安装Debian,Debian分区,虚拟机使用NAT模式联网,Linux设置静态IP

官网 https://www.debian.org/download stable是稳定版 win下amd64就行&#xff0c;macOs装arm架构的 安装Debian虚拟机 教程里没有的只管往下点就完了 哪个都行 选镜像 选安装位置 别超过宿主机内核就行 看你需求 NAT模式 虚拟 看你需求 其他的也检查一下 图形安装 选中文 继…

MoneyPrinterPlus:AI自动短视频生成工具,详细使用教程

MoneyPrinterPlus是一款使用AI大模型技术,一键批量生成各类短视频,自动批量混剪短视频,自动把视频发布到抖音,快手,小红书,视频号上的轻松赚钱工具。 之前有出过一期基本的介绍&#xff0c;但是后台收到有些小伙伴说&#xff0c;不知道如何使用。 今天我将会手把手的详细介绍…

1.动手学习深度学习课程安排及深度学习数学基础

视频资源B站&#xff1a;动手学习深度学习——李沐 目录 目标内容将学到什么1.N维数组样例2.访问2维数组元素3.数据操作4.线性代数5.矩阵计算6.自动求导 目标 介绍深度学习景点和最新模型 LeNet AlexNet VGG ResNet LSTM BERT… 机器学习基础 损失函数&#xff0c;目标函数&a…

抖音矩阵系统搭建,AI剪辑短视频,一键管理矩阵账号

目录 前言&#xff1a; 一、抖音矩阵系统有哪些功能&#xff1f; 1.AI智能文案 2.多平台账号授权 3.多种剪辑模式 4. 矩阵一键发布&#xff0c;智能发布 5.抖音爆店码功能 6.私信实时互动 7.去水印及外链 二、抖音矩阵系统可以解决哪些问题&#xff1f; 总结&#xff…

如何将接口返回/n替换为react.js中的换行符

将每个/n替换为ReactJS中的一个<br>标记。cpa_ability为后端返回的字段名

[js] 数字分开显示

<div id"number-container" class"number-container"></div>const number 123.45; // 要拆分的数字&#xff08;包括小数&#xff09; const numberContainer document.getElementById(number-container);// 将数字转换为字符串&#xff0c;…

IT架构思想---架构抽象

引言 架构的抽象思维这个概念很难解释&#xff0c;希望不会翻车&#xff0c;因为太抽象了.....&#xff0c;只能尽所能了。&#xff08;为了方便说明文章中的架构均指IT架构&#xff09; 抽象的定义 抽象是从众多的事物中抽取出共同的、本质性特征&#xff0c;而舍弃…

【二维差分】2132. 用邮票贴满网格图

本文涉及知识点 二维差分 LeetCode2132. 用邮票贴满网格图 给你一个 m x n 的二进制矩阵 grid &#xff0c;每个格子要么为 0 &#xff08;空&#xff09;要么为 1 &#xff08;被占据&#xff09;。 给你邮票的尺寸为 stampHeight x stampWidth 。我们想将邮票贴进二进制矩…

租房项目之并发缺失数据问题

前奏&#xff1a;本项目是一个基于django的租房信息获取项目。本次博客牵扯到两个版本&#xff0c;集中式分布以及分布式部署&#xff08;两个版本的ui不同&#xff0c;集中式用的是老版ui&#xff0c;分布式使用的是新版ui&#xff09;&#xff1b; 项目链接&#xff1a;http…

【C++提高编程-09】----C++ STL之常用排序算法

&#x1f3a9; 欢迎来到技术探索的奇幻世界&#x1f468;‍&#x1f4bb; &#x1f4dc; 个人主页&#xff1a;一伦明悦-CSDN博客 ✍&#x1f3fb; 作者简介&#xff1a; C软件开发、Python机器学习爱好者 &#x1f5e3;️ 互动与支持&#xff1a;&#x1f4ac;评论 &…

04 翼型和机翼、尾翼几何选择

04 翼型和机翼、尾翼几何选择 4 -1 引言4-2 翼型的选择4-2-1 翼型的几何4-2-2 翼型的升力和阻力4-2-3 翼型选择与设计4-2-4 设计升力系数4-2-5 失速4-2-6 翼型厚度比4-2-7 关于翼型其他方面的考虑 4-3 机翼几何外形4-3-1 展弦比4-2-3 机翼后掠角4-3-3 机翼稍根比4-3-4 机翼扭转…