python将日志写入文件超详细步骤

 更新时间:2024年08月05日 09:08:01   作者:风也温柔☆  
在Python中logging模块是一个强大的工具,用于记录和输出应用程序的日志信息,这篇文章主要给大家介绍了关于python将日志写入文件的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

1、需求

我们在训练模型的时候,有时候需要将训练日志输出到一个文件中,方便随时查看训练日志。

训练模型时候,训练日志在控制台展示,关闭控制台后日志会消失。这时,我们需要将控制台中的训练日志信息输出到一个指定文件中,方便我们随时查看。

将控制台中的日志信息输入到当前目录下的application.log文件中

2、方法:python logging模块

logging 是Python中非常强大且灵活的库,用于记录和跟踪应用程序运行时发生的事件。

在Python中,使用 logging 模块可以写入日志信息到指定文件。

2.1 basicConfig() 快速配置

  • 导入logging模块
  • 设置全局的日志格式和级别
  • 获取logger
  • 创建文件处理器,指定日志文件和日志级别(局部)
  • 添加文件处理器到logger
import logging
import warnings

# 忽略所有 UserWarning 警告
warnings.filterwarnings("ignore", category=UserWarning)

# 1、设置全局的日志格式和级别
logging.basicConfig(format='%(asctime)s - %(levelname)s - %(name)s - %(message)s',
                    datefmt='%m/%d/%Y %H:%M:%S',
                    level=logging.INFO)

# 2、获取logger (给日志器起个名字 "__name__")
logger = logging.getLogger(__name__)# __name__内置变量模块名称,轻松地识别出哪个模块产生了哪些日志消息(主程序模块)

# 3、创建文件处理器,指定日志文件和日志级别(局部)---文件输出FileHandle(输出到指定文件)
file_handler = logging.FileHandler('application.log') #指定日志文件名application.log,默认在当前目录下创建
file_handler.setLevel(logging.INFO) # 设置日志级别(只输出对应级别INFO的日志信息)
# 设置日志格式
file_handler.setFormatter(logging.Formatter('%(asctime)s - %(levelname)s - %(name)s - %(message)s', '%m/%d/%Y %H:%M:%S')) 

# 4、添加文件处理器到logger
logger.addHandler(file_handler)

# 训练模型的代码
epoch = 7  
# 记录日志信息
logger.info("Get better performance at epoch {}".format(epoch))

# 在主类中编写日志代码
# 判断当前程序是否为主程序,确保 main() 函数只在直接运行该Python文件时执行,如果文件被其他模块导入,则不执行 main()
# 主程序内置变量 __name__
if __name__ == "__main__":
    main()

2.2 查看application.log日志文件

2.3、logging知识

  • Loggers:应用程序中使用的接口,用于发送日志消息。它们来自logging.getLogger(name),name是用于标识logger源的字符串
  • Handlers:用于配置日志处理的目的地,如文件、控制台等。常用的有StreamHandler(控制台输出)和FileHandle(文件输出)
  • Formatters:定义最终输出中日志记录的布局
  • Filters:提供更细粒度的工具来进一步控制哪些日志记录将被输出

2.4、日志级别

debug,info,warning,error,critical
  • DEBUG:详细信息,通常只有在诊断问题时才感兴趣。
  • INFO:证明事情按预期工作(最常用)
  • WARNING:某些还不是错误的事情的指示,但是应该注意的。
  • ERROR:由于某些更严重的问题,软件已不能执行一些功能了
  • CRITICAL:严重错误,表明程序已不能继续运行。

总结 

到此这篇关于python将日志写入文件的文章就介绍到这了,更多相关python日志写入文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python中关键字Class的定义和使用方法

    Python中关键字Class的定义和使用方法

    在Python中class是用来定义类的关键字,通过class关键字可以创建一个新的类,该类可以包含属性和方法,这篇文章主要介绍了Python中关键字Class的定义和使用的相关资料,需要的朋友可以参考下
    2025-07-07
  • Python之父谈Python的未来形式

    Python之父谈Python的未来形式

    这篇文章主要介绍了Python之父谈Python的未来,需要的朋友可以参考下
    2016-07-07
  • Python+Opencv识别两张相似图片

    Python+Opencv识别两张相似图片

    python的功能实在太强大,这篇文章主要介绍了Python+Opencv识别两张相似图片的相关资料,文中利用Opencv库进行了更简洁化的实现,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • python orm 框架中sqlalchemy用法实例详解

    python orm 框架中sqlalchemy用法实例详解

    这篇文章主要介绍了python orm 框架中sqlalchemy用法,结合实例形式详细分析了Python orm 框架基本概念、原理及sqlalchemy相关使用技巧,需要的朋友可以参考下
    2020-02-02
  • python保存图片的四个常用方法

    python保存图片的四个常用方法

    这篇文章主要给大家介绍了关于python保存图片的四个常用方法,文中分别介绍了PIL的保存图片方法、opencv保存图片、Matplotlib保存图片的方法以及pytorch保存图片,需要的朋友可以参考下
    2022-02-02
  • Python学习之迭代器详解

    Python学习之迭代器详解

    这篇文章主要介绍了Python中的一个新的概念,那就是迭代器 。迭代器的使用可以帮助我们提升代码的性能,接下来让我们深入了解一下迭代器吧
    2022-04-04
  • Python中实现定时任务常见的几种方式

    Python中实现定时任务常见的几种方式

    在Python中,实现定时任务是一个常见的需求,无论是在自动化脚本、数据处理、系统监控还是其他许多应用场景中,Python提供了多种方法来实现定时任务,包括使用标准库、第三方库以及系统级别的工具,本文将详细介绍几种常见的Python定时任务实现方式
    2024-08-08
  • Python API 自动化实战详解(纯代码)

    Python API 自动化实战详解(纯代码)

    今天小编就为大家分享一篇Python API 自动化实战详解(纯代码),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-06-06
  • 对pycharm 修改程序运行所需内存详解

    对pycharm 修改程序运行所需内存详解

    今天小编就为大家分享一篇对pycharm 修改程序运行所需内存详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-12-12
  • Python使用matplotlib时显示中文乱码解决方法(或更改字体)

    Python使用matplotlib时显示中文乱码解决方法(或更改字体)

    这篇文章主要给大家介绍了关于Python使用matplotlib时显示中文乱码的解决方法(或更改字体),在Matplotlib中,中文乱码问题通常出现在图表的标题、标签和刻度上,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12

最新评论