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

本文主要是介绍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关键字就是生成器

使用场景:

例如斐波那契数列

这篇关于python相关知识-logging日志、property属性、上下文管理器、生成器等的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1071216

相关文章

SpringBoot日志配置SLF4J和Logback的方法实现

《SpringBoot日志配置SLF4J和Logback的方法实现》日志记录是不可或缺的一部分,本文主要介绍了SpringBoot日志配置SLF4J和Logback的方法实现,文中通过示例代码介绍的非... 目录一、前言二、案例一:初识日志三、案例二:使用Lombok输出日志四、案例三:配置Logback一

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

golang 日志log与logrus示例详解

《golang日志log与logrus示例详解》log是Go语言标准库中一个简单的日志库,本文给大家介绍golang日志log与logrus示例详解,感兴趣的朋友一起看看吧... 目录一、Go 标准库 log 详解1. 功能特点2. 常用函数3. 示例代码4. 优势和局限二、第三方库 logrus 详解1.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调