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

相关文章

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

Python日期和时间完全指南与实战

《Python日期和时间完全指南与实战》在软件开发领域,‌日期时间处理‌是贯穿系统设计全生命周期的重要基础能力,本文将深入解析Python日期时间的‌七大核心模块‌,通过‌企业级代码案例‌揭示最佳实践... 目录一、背景与核心价值二、核心模块详解与实战2.1 datetime模块四剑客2.2 时区处理黄金法

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

MySQL精准控制Binlog日志数量的三种方案

《MySQL精准控制Binlog日志数量的三种方案》作为数据库管理员,你是否经常为服务器磁盘爆满而抓狂?Binlog就像数据库的“黑匣子”,默默记录着每一次数据变动,但若放任不管,几天内这些日志文件就... 目录 一招修改配置文件:永久生效的控制术1.定位my.cnf文件2.添加核心参数不重启热更新:高手应

python通过curl实现访问deepseek的API

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... API申请和充值下面是deepeek的API网站https://platform.deepsee

Python Selenium动态渲染页面和抓取的使用指南

《PythonSelenium动态渲染页面和抓取的使用指南》在Web数据采集领域,动态渲染页面已成为现代网站的主流形式,本文将从技术原理,环境配置,核心功能系统讲解Selenium在Python动态... 目录一、Selenium技术架构解析二、环境搭建与基础配置1. 组件安装2. 驱动配置3. 基础操作模

Python将字库文件打包成可执行文件的常见方法

《Python将字库文件打包成可执行文件的常见方法》在Python打包时,如果你想将字库文件一起打包成一个可执行文件,有几种常见的方法,具体取决于你使用的打包工具,下面就跟随小编一起了解下具体的实现方... 目录使用 PyInstaller基本方法 - 使用 --add-data 参数使用 spec 文件(

Python MCPInspector调试思路详解

《PythonMCPInspector调试思路详解》:本文主要介绍PythonMCPInspector调试思路详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录python-MCPInspector调试1-核心知识点2-思路整理1-核心思路2-核心代码3-参考网址

将图片导入Python的turtle库的详细过程

《将图片导入Python的turtle库的详细过程》在Python编程的世界里,turtle库以其简单易用、图形化交互的特点,深受初学者喜爱,随着项目的复杂度增加,仅仅依靠线条和颜色来绘制图形可能已经... 目录开篇引言正文剖析1. 理解基础:Turtle库的工作原理2. 图片格式与支持3. 实现步骤详解第