Python 日志文件按日期自动分割保存

使用TimedRotatingFileHandler按日期分割日志,通过设置when=”midnight”、interval=1和backupCount=7,可实现每天自动生成新日志文件并保留最近7天记录。配合namer和rotator可自定义归档文件名格式,适用于长期运行服务的日志管理。

python 日志文件按日期自动分割保存

Python 中实现日志文件按日期自动分割保存,最常用的方式是使用内置的 logging 模块配合 TimedRotatingFileHandler。这种方式可以根据时间间隔(如每天)自动创建新的日志文件,旧的日志也可以设置保留期限。

1. 使用 TimedRotatingFileHandler 按天分割日志

下面是一个按天生成日志文件的基本示例:

import loggingfrom logging.handlers import TimedRotatingFileHandlerimport os

日志目录

log_dir = "logs"os.makedirs(log_dir, exist_ok=True)

配置日志器

logger = logging.getLogger("daily_logger")logger.setLevel(logging.INFO)

定义处理器:每天生成一个新文件,保留最近 7 天的日志

handler = TimedRotatingFileHandler(filename=os.path.join(log_dir, "app.log"),when="midnight", # 在午夜切换interval=1, # 每1天切换一次backupCount=7, # 最多保留7个备份encoding="utf-8")handler.suffix = "%Y-%m-%d" # 文件名后缀格式

设置日志格式

formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')handler.setFormatter(formatter)

添加处理器到日志器

logger.addHandler(handler)

示例日志输出

logger.info("这是一条测试日志")

立即学习Python免费学习笔记(深入)”;

运行后,会在 logs 目录下生成类似 app.log.2024-04-05app.log.2024-04-06 的文件。当前日志写入 app.log,每天凌晨自动重命名并创建新文件。

2. 自定义日志文件名格式

默认情况下,suffix 控制归档文件的时间格式。如果想让原始日志也带日期,可以自定义命名逻辑:

import time

修改 handler 的命名方式

def namer(default_name):return default_name + ".log"

def rotator(source, dest):os.rename(source, dest + ".log")

handler.namer = namer

挖错网
挖错网

一款支持文本、图片、视频纠错和AIGC检测的内容审核校对平台。

挖错网 185
查看详情 挖错网

handler.rotator = rotator # 可选:自定义压缩等操作

这样归档文件会变成 app.log.2024-04-05.log,更清晰易识别。

3. 常见配置说明

when 参数支持的时间单位:

S: 秒M: 分钟H: 小时D: 天midnight: 每天午夜

interval 表示切换频率,如 when=”H”, interval=2 表示每两小时切一次。

4. 注意事项

确保程序长时间运行,才能触发自动分割。如果是短脚本,可手动调用 doRollover() 测试。

多进程环境下,TimedRotatingFileHandler 可能出现竞争问题,建议结合 concurrent-log-handler 第三方库解决。

基本上就这些。按日期分割日志对长期运行的服务非常实用,便于归档和排查问题。配置一次,后续自动管理,省心又规范。

以上就是Python 日志文件按日期自动分割保存的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1380991.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 22:34:43
下一篇 2025年12月14日 22:34:55

相关推荐

  • Python爬虫怎样设置代理IP_Python爬虫使用代理IP防止封禁的设置方法

    使用代理IP可避免爬虫IP被封,常见方法包括:requests库通过proxies参数设置;urllib模块配置ProxyHandler;Selenium在ChromeOptions中添加代理;建议轮换多个代理并检测有效性,配合请求频率控制与User-Agent切换提升效果。 在使用Python爬虫…

    好文分享 2025年12月14日
    000
  • python函数装饰器的应用过程

    函数装饰器是Python中通过闭包和语法糖为函数添加功能的技术,使用@符号将装饰器应用于目标函数,等价于将原函数作为参数传入装饰器并接收返回的新函数。装饰器内部通常包含一个包装函数(wrapper),用于在原函数执行前后插入额外逻辑,如日志、计时或权限校验。对于带参数的函数,装饰器需使用args和*…

    2025年12月14日
    000
  • 如何在 Python 项目中强制指定解释器版本

    在Python项目中强制指定解释器版本可通过pyproject.toml实现,推荐在[project]下设置requires-python=”>=3.9″以约束版本兼容性。 在 Python 项目中强制指定解释器版本,主要是为了确保项目运行在预期的 Python 版本上…

    2025年12月14日
    000
  • Python调用API接口如何调用股票API_Python调用股票数据API接口获取实时行情的方法

    可通过Python调用金融数据API获取实时股票行情。一、使用requests库发送HTTP请求,解析JSON数据获取股票信息;二、利用tushare库,注册并获取Token后可访问A股市场数据;三、通过Alpha Vantage API获取全球股票数据,需注册获取API Key,支持高频数据;四、…

    2025年12月14日
    000
  • Python爬虫怎样使用CSV存储数据_Python爬虫将抓取结果保存为CSV文件方法

    答案:Python爬虫可用csv模块或pandas将数据保存为CSV文件。1. 使用csv模块可写入表头和数据,适合结构化信息存储;2. pandas能自动处理编码与中文,导出更便捷;3. 需用try-except处理异常,with确保文件安全关闭。 Python爬虫抓取数据后,使用CSV格式存储是…

    2025年12月14日
    000
  • Python如何实现字符串排序

    使用sorted()可对字符串字符或列表排序,按字母、长度或自定义规则。1. 字符排序用”.join(sorted(s));2. 列表排序默认按字典序,忽略大小写加key=str.lower;3. 按长度排序用key=len;4. 自定义规则可用lambda函数实现,如先按长度再按字母排…

    2025年12月14日
    000
  • Python ImportError 与 ModuleNotFoundError 区别

    ImportError 是导入模块时的通用异常,涵盖模块存在但导入内容不存在或内部错误等情况;2. ModuleNotFoundError 是其子类,自 Python 3.6 起引入,专用于表示模块未找到;3. 可通过 except ModuleNotFoundError 单独捕获模块缺失,或用 e…

    2025年12月14日
    000
  • Python 文件索引与搜索的实现方法

    答案:使用pathlib和os模块遍历目录,构建包含文件元数据的索引列表,通过关键字匹配实现文件名与内容搜索,并可用defaultdict优化查询效率。 在Python中实现文件索引与搜索,核心是遍历目录结构、提取文件信息并建立可快速查询的数据结构。常见场景包括本地文件检索、日志分析、代码库搜索等。…

    2025年12月14日
    000
  • python中Pyramid框架是什么?

    Pyramid 是一个灵活可扩展的 Python Web 框架,适合从小型应用到大型系统的开发。它源自 Pylons 项目,强调最少假设,允许自由选择数据库、模板引擎等组件。支持 URL 路由映射和灵活的安全模型,内置认证与授权机制,可扩展性强,适用于简单脚本至企业级服务。文档完善,社区稳定,适合长…

    2025年12月14日
    000
  • Python 变量命名规则与最佳实践

    Python变量命名需遵循规则并采用最佳实践以提升代码可读性。1. 变量名只能包含字母、数字和下划线,不可数字开头;2. 避免关键字如if、for;3. 区分大小写,_开头有特殊含义;4. 推荐snake_case命名变量函数,PascalCase命名类,UPPER_CASE命名常量;5. 使用有意…

    2025年12月14日
    000
  • python中for循环如何对大于某值的数字求和_python中for循环筛选并求和大于指定值数字的方法

    首先通过for循环遍历列表,结合条件判断筛选大于阈值的数并累加求和。例如遍历numbers列表,将大于threshold的元素相加,最终输出符合条件的数字总和为115。 在Python中,使用for循环对大于某个指定值的数字求和,可以通过遍历列表或其他可迭代对象,结合条件判断来实现。下面介绍具体方法…

    2025年12月14日 好文分享
    000
  • python中如何用for循环求等比数列和_python中for循环计算等比数列总和的实例代码

    先用for循环累加各项计算等比数列和,首项a=2、公比r=3、项数n=5时,各项为2, 6, 18, 54, 162,总和为242;可封装为geometric_sum(a, r, n)函数,便于重复调用。 在Python中,可以用for循环来计算等比数列的总和。等比数列是指从第二项起,每一项与前一项…

    2025年12月14日 好文分享
    000
  • venv 与 conda 环境互相切换的方法

    venv和conda是互不兼容的虚拟环境工具,切换需先退出当前环境再激活另一个。2. 从conda切到venv:执行conda deactivate后运行source /path/to/venv/bin/activate(Linux/macOS)或pathoenvScriptsctivate(Win…

    2025年12月14日
    000
  • python中使用Dockerfile构建镜像

    答案:使用Dockerfile可将Python项目及其依赖打包为一致的容器镜像。首先组织项目结构包含app.py、requirements.txt和Dockerfile;接着编写Dockerfile,基于python:3.9-slim镜像,设置工作目录为/app,先复制并安装依赖,再复制代码,暴露5…

    2025年12月14日 好文分享
    000
  • Python爬虫如何设置请求头_Python爬虫设置请求头模拟浏览器访问方法

    设置请求头可模拟浏览器行为,避免被识别为爬虫。通过requests的headers参数添加User-Agent、Accept等字段,使服务器误认为请求来自真实用户,提高爬取成功率,并可通过随机切换User-Agent增强隐蔽性。 在使用Python编写爬虫时,很多网站会通过检查请求头(Request…

    2025年12月14日
    000
  • python创建和使用堆的方法

    Python通过heapq模块实现最小堆,可对列表进行堆化、插入、弹出等操作,支持高效获取极值及模拟最大堆。 Python 中没有专门的“堆”类型,但可以通过内置模块 heapq 来创建和使用堆。heapq 模块提供了对列表进行堆操作的函数,实现的是最小堆(min-heap)结构。 1. 创建堆 堆…

    2025年12月14日
    000
  • Python多线程如何实现工作窃取 Python多线程负载均衡策略

    Python多线程受GIL限制无法真正并行,但可通过模拟工作窃取提升效率。1. 工作窃取指线程用双端队列存任务,空闲时从其他线程尾部窃取任务执行,减少空闲。2. queue.Queue可实现中心化任务分发,多线程从中取任务,达到负载均衡。3. 用collections.deque为每个线程配本地队列…

    2025年12月14日
    000
  • 如何在服务器上搭建 Python 环境

    首先确认服务器系统类型和管理员权限,然后安装Python 3及pip工具;Ubuntu/Debian使用apt命令,CentOS/RHEL使用yum或dnf;接着安装python3-venv创建虚拟环境,通过python3 -m venv myproject_env和source myproject…

    2025年12月14日
    000
  • python中PyMySQL有什么用

    PyMySQL是Python操作MySQL的轻量库,支持连接数据库、执行SQL、参数化查询防注入、事务管理,并需手动关闭游标和连接。 PyMySQL 是 Python 中用于连接和操作 MySQL 数据库的一个纯 Python 实现的客户端库。它的主要作用是让 Python 程序能够与 MySQL …

    2025年12月14日
    000
  • Python 项目如何实现一键安装依赖

    使用requirements.txt可实现Python项目依赖的一键安装,首先通过pip freeze > requirements.txt导出依赖,建议仅保留直接依赖并规范版本控制符如==、>=、~=,然后用户可通过pip install -r requirements.txt在虚拟环…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信