运维入门- python实现对.log日志文件的无用行内容过滤,便于留存有价值的信息

本文主要是介绍运维入门- python实现对.log日志文件的无用行内容过滤,便于留存有价值的信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码原文:

def remove_offline_messages(file_path):try:# 打开文件并读取所有行with open(file_path, 'r', encoding='utf-8') as file:lines = file.readlines()# 过滤掉包含'pc消息离线pcadmin'的行filtered_lines = [line for line in lines if '丢弃消息======' not in line]# 将过滤后的内容写回文件with open(file_path, 'w', encoding='utf-8') as file:file.writelines(filtered_lines)print("文件处理完成,相关行已删除。")except Exception as e:print(f"处理文件时出错: {e}")# 使用方法
file_path = 'ws_business.log'
remove_offline_messages(file_path)

这段 Python 代码定义了一个函数 remove_offline_messages,用于从指定文件中删除包含特定字符串的行,并将处理后的内容写回文件。下面是对这段代码的详细解释:

函数定义

def remove_offline_messages(file_path):
  • def:定义一个函数。
  • remove_offline_messages:函数名,表示删除离线消息。
  • file_path:函数参数,表示要处理的文件路径。

尝试读取文件并处理

try:
  • try:开始一个异常处理块,用于捕获和处理可能出现的异常。
打开文件并读取所有行
# 打开文件并读取所有行
with open(file_path, 'r', encoding='utf-8') as file:lines = file.readlines()
  • with open(file_path, 'r', encoding='utf-8') as file:使用 with 语句以只读模式 ('r') 打开文件,编码方式为 utf-8with 语句会在 file 对象退出上下文时自动关闭文件。
  • file.readlines():读取文件中的所有行,并将它们存储在 lines 列表中,每一行作为列表的一个元素。
过滤掉不需要的行
# 过滤掉包含'丢弃消息======'的行
filtered_lines = [line for line in lines if '丢弃消息======' not in line]
  • 列表推导式 filtered_lines = [line for line in lines if '丢弃消息======' not in line]:遍历 lines 列表,将不包含字符串 '丢弃消息======' 的行保留,形成新的列表 filtered_lines
将过滤后的内容写回文件
# 将过滤后的内容写回文件
with open(file_path, 'w', encoding='utf-8') as file:file.writelines(filtered_lines)
  • with open(file_path, 'w', encoding='utf-8') as file:使用 with 语句以写入模式 ('w') 打开文件,编码方式为 utf-8。此时文件内容会被清空。
  • file.writelines(filtered_lines):将 filtered_lines 列表中的每一行写入文件。

打印处理完成信息

print("文件处理完成,相关行已删除。")
  • print:输出提示信息,表示文件处理已完成,并且相关行已被删除。

异常处理

except Exception as e:print(f"处理文件时出错: {e}")
  • except Exception as e:捕获所有异常,并将异常实例赋值给 e
  • print(f"处理文件时出错: {e}"):输出异常信息,提示处理文件时出现了错误,并显示具体的异常内容。

函数调用

# 使用方法
file_path = 'ws_business.log'
remove_offline_messages(file_path)
  • file_path = 'ws_business.log':定义文件路径变量,指向要处理的日志文件。
  • remove_offline_messages(file_path):调用 remove_offline_messages 函数,传入文件路径,执行文件内容的过滤和写入操作。

代码的功能和目的

  • 功能:从指定文件中删除包含特定字符串(‘丢弃消息======’)的行,并将处理后的文件内容写回原文件。
  • 目的:清理日志文件或其他文本文件,移除不需要的或不相关的信息,保持文件内容的整洁。

应用场景

  • 清理日志文件,移除不必要的消息,减少文件体积。
  • 过滤数据文件,删除包含特定关键词的行。

文章介绍由chatgpt协助整理

这篇关于运维入门- python实现对.log日志文件的无用行内容过滤,便于留存有价值的信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

详解python pycharm与cmd中制表符不一样

《详解pythonpycharm与cmd中制表符不一样》本文主要介绍了pythonpycharm与cmd中制表符不一样,这个问题通常是因为PyCharm和命令行(CMD)使用的制表符(tab)的宽... 这个问题通常是因为PyCharm和命令行(CMD)使用的制表符(tab)的宽度不同导致的。在PyChar

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方