当前位置: 首页 > news >正文

简单实现log记录保存到文本和数据库

简单保存记录到txt,sqlite数据库,以及console监控记录

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Text;
using System.Data.SQLite;
using System.IO;namespace NlogFrame
{public enum  LogType{Trace,Consl,Debug,Info,Warn,Error,Fatal}public class Log{/// <summary>/// 最大缓存数/// </summary>[Browsable(true)]public static int MaxTempListCnt { get; set; } = 300;[Browsable(true)]public static LogType MinLevel { get; set; } = 0;[Browsable(true)]public static bool DebugEnable { get; set; } = true;[Browsable(true)]public static bool TraceEnable { get; set; } = true;[Browsable(true)]public static bool WarnEnable { get; set; } = true;static bool _ConsoleEnable = false;static TextWriter originalOut = null;[Browsable(true)]public static bool ConsoleEnable{get { return _ConsoleEnable; }set{_ConsoleEnable = value;if (value == true){if (originalOut == null){originalOut = Console.Out;}Console.SetOut(logConsole);}else{if (originalOut != null){Console.SetOut(originalOut);originalOut = null;}}}}[Browsable(true)]public string Name { get; set; } = "";static LogConsole logConsole = new LogConsole();public static List<LogInfo> TempLogInfoList => _TempLogInfoList;static List<LogInfo> _TempLogInfoList;public Log(string name){Name = name;}public void Error(string msg){if ((int)LogType.Error >= (int)MinLevel){//logger.Error(msg);AddLog(new LogInfo(DateTime.Now, LogType.Error, msg));}}public void Consl(string msg){if ((int)LogType.Consl >= (int)MinLevel){//logger.Error(msg);AddLog(new LogInfo(DateTime.Now, LogType.Consl, msg));}}public void Trace(string msg){if ((int)LogType.Trace >= MinLevel){// logger.Trace(msg);AddLog(new LogInfo(DateTime.Now, LogType.Trace, msg));}}public void Warn (string msg){if ((int)LogType.Warn >= (int)MinLevel){// logger.Warn(msg);AddLog(new LogInfo(DateTime.Now, LogType.Warn, msg));}}public void Info(string msg){if ((int)LogType.Info >= (int)MinLevel){//logger.Info(msg);AddLog(new LogInfo(DateTime.Now, LogType.Info, msg));}}public void Debug(string msg){if ((int)LogType.Debug >= (int)MinLevel){// logger.Debug(msg);AddLog(new LogInfo(DateTime.Now, LogType.Debug, msg));}}public void Fatal(string msg){if ((int)LogType.Fatal >= (int)MinLevel){//logger.Fatal(msg);AddLog(new LogInfo(DateTime.Now, LogType.Fatal, msg));}}public void WriteLogTxt(LogInfo info){// 定义日志文件的路径  string logFilePath = Environment.CurrentDirectory + "\\logs\\log-" + DateTime.Now.Date.ToString("yyyy-mm-dd") + ".txt";if (!Directory.Exists(Environment.CurrentDirectory + "\\logs\\"))Directory.CreateDirectory(Environment.CurrentDirectory + "\\logs\\");// 使用StreamWriter写入日志  // 如果文件不存在,它将被创建;如果文件已存在,则默认是追加模式  using (StreamWriter writer = new StreamWriter(logFilePath, true)) // 第二个参数为true表示追加模式  {// 写入日志信息  writer.WriteLine(info.ToString());// 你可以继续写入更多的日志信息  }}public void WriteLogSqlite(LogInfo info){// 定义日志文件的路径  string logFilePath = Environment.CurrentDirectory + "\\logs\\db-" + DateTime.Now.Date.ToString("yyyy-mm-dd") + ".db";if (!Directory.Exists(Environment.CurrentDirectory + "\\logs\\"))Directory.CreateDirectory(Environment.CurrentDirectory + "\\logs\\");// 创建数据库(如果尚不存在)  using (var connection = new SQLiteConnection($"Data Source={logFilePath}")){connection.Open();// 创建一个表(如果尚不存在)  string createTableSql = @"  CREATE TABLE IF NOT EXISTS Log (  Id INTEGER PRIMARY KEY AUTOINCREMENT,  Time TEXT NOT NULL,  Name TEXT , Type INTEGER , Message TEXT)";using (var command = new SQLiteCommand(createTableSql, connection)){command.ExecuteNonQuery();}// 插入数据  string insertSql = "INSERT INTO Log (Time,Name ,Type , Message) VALUES (@Time,@Name,@Type, @Message)";using (var command = new SQLiteCommand(insertSql, connection)){command.Parameters.AddWithValue("@Time", info.Time.ToString("yyyy-MM-dd HH:mm:ss.fff"));command.Parameters.AddWithValue("@Name", info.Name);command.Parameters.AddWithValue("@Type", info.Type);command.Parameters.AddWithValue("@Message",info.Message);command.ExecuteNonQuery();}}}public void DeleteFile(){// 指定你想要遍历的文件夹路径  string folderPath = @"C:\你的文件夹路径";// 获取文件夹中的所有文件  string[] files = Directory.GetFiles(folderPath);// 遍历文件  foreach (string file in files){// 获取文件的创建时间  FileInfo fileInfo = new FileInfo(file);DateTime creationTime = fileInfo.CreationTime;// 计算自文件创建以来的天数  TimeSpan span = DateTime.Now - creationTime;double days = span.TotalDays;// 如果文件创建时间超过20天  if (days > 20){try{// 删除文件  File.Delete(file);//Console.WriteLine($"已删除文件: {file}");}catch (Exception ex){// 处理删除文件时可能出现的异常,例如文件正在使用中  Console.WriteLine($"无法删除文件: {file}. 错误: {ex.Message}");}}}Console.WriteLine("处理完成。");Console.ReadKey(); // 暂停,以便查看输出  }private void AddLog(LogInfo info){info.Name = Name;WriteLogTxt(info);WriteLogSqlite(info);if (_TempLogInfoList == null){_TempLogInfoList = new List<LogInfo>();}while (_TempLogInfoList.Count > MaxTempListCnt){_TempLogInfoList.RemoveAt(0);}_TempLogInfoList.Add(info);}}public class LogInfo{[Description("时间")]public DateTime Time { get; set; }[Description("类型")]public LogType Type { get; set; }[Description("对象")]public string Name { get; set; }[Description("信息")]public string Message { get; set; }public LogInfo(DateTime dateTime, LogType type, string msg){Time = dateTime;Type = type;Message = msg;}public override string ToString() => Time.ToString("yyyy-MM-dd HH:mm:ss.fff") + " | " + Type + " | " + Name + " | " + Message;}public class LogConsole : TextWriter{private StringBuilder _sb = new StringBuilder();public override Encoding Encoding => throw new NotImplementedException();public override void WriteLine(string value){Log console = new Log("控制台");//_sb.AppendLine(value);// 这里可以添加额外的逻辑,比如记录到文件或数据库  console.Consl(value);Console.WriteLine($"Intercepted: {value}");//Console.WriteLine($"Intercepted: {value}"); // 仅为了演示  }// 你可以根据需要实现其他重写的方法  // 一个方法用于获取或清空收集的输出  public string GetAndClearOutput(){string output = _sb.ToString();_sb.Clear();return output;}}
}

相关文章:

简单实现log记录保存到文本和数据库

简单保存记录到txt&#xff0c;sqlite数据库&#xff0c;以及console监控记录 using System; using System.Collections.Generic; using System.ComponentModel; using System.Text; using System.Data.SQLite; using System.IO;namespace NlogFrame {public enum LogType{Tr…...

敏感字段加密 - 华为OD统一考试(E卷)

2024华为OD机试(E卷+D卷+C卷)最新题库【超值优惠】Java/Python/C++合集 题目描述 【敏感字段加密】给定一个由多个命令字组成的命令字符串: 1、字符串长度小于等于127字节,只包含大小写字母,数字,下划线和偶数个双引号; 2、命令字之间以一个或多个下划线 进行分割; 3、可…...

go 安装三方库

go版本 go versiongo version go1.23.1 darwin/arm64安装 redis 库 cd $GOPATH说明&#xff1a; 这里可以改 GOPATH的值 将如下 export 语句写入 ~/.bash_profile 文件中 export GOPATH/Users/goproject然后使其生效 source ~/.bash_profile初始化生成 go.mod 文件 go mod…...

Java 中的 volatile和synchronized和 ReentrantLock区别讲解和案例示范

在 Java 的并发编程中&#xff0c;volatile、synchronized 和 ReentrantLock 是三种常用的同步机制。每种机制都有其独特的特性、优缺点和适用场景。理解它们之间的区别以及在何种情况下使用哪种机制&#xff0c;对提高程序的性能和可靠性至关重要。本文将详细探讨这三种机制的…...

从GDAL中 读取遥感影像的信息

从GDAL提供的实用程序来看&#xff0c;很多程序的后缀都是 .py &#xff0c;这充分地说明了Python语言在GDAL的开发中得到了广泛的应用。 1. 打开已有的GeoTIF文件 下面我们试着读取一个GeoTiff文件的信息。第一步就是打开一个数据集。 >>> from osgeo import gdal…...

算法闭关修炼百题计划(一)

多看优秀的代码一定没有错&#xff0c;此篇博客属于个人学习记录 1.两数之和2.前k个高频元素3.只出现一次的数字4.数组的度5.最佳观光组合6.整数反转7.缺失的第一个正数8.字符串中最多数目的子序列9.k个一组翻转链表10.反转链表II11. 公司命名12.合并区间13.快速排序14.数字中的…...

vue3实现打字机的效果,可以换行

之前看了很多文章,效果是实现了,就是没有自动换行的效果,参考了文章写了一个,先上个效果图,卡顿是因为模仿了卡顿的效果,还是很丝滑的 目录 效果图:代码如下 效果图: ![请添加图片描述](https://i-blog.csdnimg.cn/direct/d8ef33d83dd3441a87d6d033d9e7cafa.gif 代码如下 原…...

【如何学习操作系统】——学会学习的艺术

&#x1f41f;作者简介&#xff1a;一名大三在校生&#xff0c;喜欢编程&#x1fab4; &#x1f421;&#x1f419;个人主页&#x1f947;&#xff1a;Aic山鱼 &#x1f420;WeChat&#xff1a;z7010cyy &#x1f988;系列专栏&#xff1a;&#x1f3de;️ 前端-JS基础专栏✨前…...

stm32 flash无法擦除

通过bushound调试代码发现&#xff0c;当上位机发送命令到模组后flash将不能擦除&#xff0c;通过 HAL_FLASH_GetError&#xff08;&#xff09;函数查找原因是FLASH Programming Sequence error&#xff08;编程顺序错误&#xff09;&#xff0c;解决办法是在解锁后清零标志位…...

Android—ANR日志分析

获取ANR日志&#xff1a; ANR路径&#xff1a;/data/anrADB指令&#xff1a;adb bugreport D:\bugrep.zip ANR日志分析步骤&#xff1a; “main” prio&#xff1a;主线程状态beginning of crash&#xff1a;搜索 crash 相关信息CPU usage from&#xff1a;搜索 cpu 使用信息…...

9.29 LeetCode 3304、3300、3301

思路&#xff1a; ⭐进行无限次操作&#xff0c;但是 k 的取值小于 500 &#xff0c;所以当 word 的长度大于 500 时就可以停止操作进行取值了 如果字符为 ‘z’ &#xff0c;单独处理使其变为 ‘a’ 得到得到操作后的新字符串&#xff0c;和原字符串拼接 class Solution { …...

近万字深入讲解iOS常见锁及线程安全

什么是锁&#xff1f; 在程序中&#xff0c;当多个任务&#xff08;或线程&#xff09;同时访问同一个资源时&#xff0c;比如多个操作同时修改一份数据&#xff0c;可能会导致数据不一致。这时候&#xff0c;我们需要“锁”来确保同一时间只有一个任务能够操作这个数据&#…...

linux创建固定大小的文件夹用于测试

在linux上创建固定大小的文件夹用于测试磁盘空间不足时的应用故障。 实验环境为centos7&#xff0c;有两种简易方法&#xff1a; 一、使用ramdisk 1、创建文件夹 mkdir /var/mytest 2、创建一个1m大小的临时文件 mount none /var/mytest -t tmpfs -o size1m size也可以写…...

大模型学习路线:这会是你见过最全最新的大模型学习路线【2024最新】

大模型学习路线 建议先从主流的Llama开始&#xff0c;然后选用中文的Qwen/Baichuan/ChatGLM&#xff0c;先快速上手体验prompt工程&#xff0c;然后再学习其架构&#xff0c;跑微调脚本 如果要深入学习&#xff0c;建议再按以下步骤&#xff0c;从更基础的GPT和BERT学起&…...

了解云计算工作负载保护的重要性,确保数据和应用程序安全

云计算de小白 云计算技术的快速发展使数据和应用程序安全成为一种关键需求&#xff0c;而不仅仅是一种偏好。随着越来越多的客户公司将业务迁移到云端&#xff0c;保护他们的云工作负载&#xff08;指所有部署的应用程序和服务&#xff09;变得越来越重要。云工作负载保护&…...

Swagger3基本使用

Swagger 课程目标 Swagger简介【了解】 Springboot整合swagger【掌握】 Swagger 常用注解【掌握】 knife4j-Swagger【会用】 一、Swagger3简介 Swagger 是一系列 RESTful API 的工具&#xff0c;通过 Swagger 可以获得项目的⼀种交互式文档&#xff0c;客户端 SDK 的自 动…...

如何借助Java批量操作Excel文件?

最新技术资源&#xff08;建议收藏&#xff09; https://www.grapecity.com.cn/resources/ 前言 | 问题背景 在操作Excel的场景中&#xff0c;通常会有一些针对Excel的批量操作&#xff0c;批量的意思一般有两种&#xff1a; 对批量的Excel文件进行操作。如导入多个Excel文件…...

JUC并发编程_Lock锁

JUC并发编程_Lock锁 1、Lock锁介绍2、主要方法3、与 synchronized 的区别4、Condition 使用示例 1、Lock锁介绍 Java中的 Lock 锁是 java.util.concurrent.locks 包下的一个接口&#xff0c;它提供了比 synchronized 关键字更灵活的锁定机制。 2、主要方法 lock()&#xff1a…...

Unity中的功能解释(数学位置相关和事件)

向量计算 Vector3.Slerp&#xff08;起点坐标&#xff0c;终点坐标&#xff0c;t&#xff09;&#xff0c;可是从起点坐标以一个圆形轨迹到终点坐标&#xff0c;有那么多条轨迹&#xff0c;那怎么办 Vector3.Slerp 进行的是沿球面插值&#xff0c;因此并不是沿着严格的“圆形…...

ElementPlus---Timeline 时间线组件使用示例

介绍 使用ElementPlus时间线组件在后台首页实现通知公告列表展示&#xff0c;使用Vue3开发。 实现代码 Vue3代码 <el-timeline><el-timeline-itemstyle"max-width: 600px"v-for"(activity, index) in activities":key"index":times…...

eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)

说明&#xff1a; 想象一下&#xff0c;你正在用eNSP搭建一个虚拟的网络世界&#xff0c;里面有虚拟的路由器、交换机、电脑&#xff08;PC&#xff09;等等。这些设备都在你的电脑里面“运行”&#xff0c;它们之间可以互相通信&#xff0c;就像一个封闭的小王国。 但是&#…...

基于Flask实现的医疗保险欺诈识别监测模型

基于Flask实现的医疗保险欺诈识别监测模型 项目截图 项目简介 社会医疗保险是国家通过立法形式强制实施&#xff0c;由雇主和个人按一定比例缴纳保险费&#xff0c;建立社会医疗保险基金&#xff0c;支付雇员医疗费用的一种医疗保险制度&#xff0c; 它是促进社会文明和进步的…...

Psychopy音频的使用

Psychopy音频的使用 本文主要解决以下问题&#xff1a; 指定音频引擎与设备&#xff1b;播放音频文件 本文所使用的环境&#xff1a; Python3.10 numpy2.2.6 psychopy2025.1.1 psychtoolbox3.0.19.14 一、音频配置 Psychopy文档链接为Sound - for audio playback — Psy…...

数据库分批入库

今天在工作中&#xff0c;遇到一个问题&#xff0c;就是分批查询的时候&#xff0c;由于批次过大导致出现了一些问题&#xff0c;一下是问题描述和解决方案&#xff1a; 示例&#xff1a; // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

Android15默认授权浮窗权限

我们经常有那种需求&#xff0c;客户需要定制的apk集成在ROM中&#xff0c;并且默认授予其【显示在其他应用的上层】权限&#xff0c;也就是我们常说的浮窗权限&#xff0c;那么我们就可以通过以下方法在wms、ams等系统服务的systemReady()方法中调用即可实现预置应用默认授权浮…...

Rapidio门铃消息FIFO溢出机制

关于RapidIO门铃消息FIFO的溢出机制及其与中断抖动的关系&#xff0c;以下是深入解析&#xff1a; 门铃FIFO溢出的本质 在RapidIO系统中&#xff0c;门铃消息FIFO是硬件控制器内部的缓冲区&#xff0c;用于临时存储接收到的门铃消息&#xff08;Doorbell Message&#xff09;。…...

LangChain知识库管理后端接口:数据库操作详解—— 构建本地知识库系统的基础《二》

这段 Python 代码是一个完整的 知识库数据库操作模块&#xff0c;用于对本地知识库系统中的知识库进行增删改查&#xff08;CRUD&#xff09;操作。它基于 SQLAlchemy ORM 框架 和一个自定义的装饰器 with_session 实现数据库会话管理。 &#x1f4d8; 一、整体功能概述 该模块…...

【电力电子】基于STM32F103C8T6单片机双极性SPWM逆变(硬件篇)

本项目是基于 STM32F103C8T6 微控制器的 SPWM(正弦脉宽调制)电源模块,能够生成可调频率和幅值的正弦波交流电源输出。该项目适用于逆变器、UPS电源、变频器等应用场景。 供电电源 输入电压采集 上图为本设计的电源电路,图中 D1 为二极管, 其目的是防止正负极电源反接, …...

MySQL JOIN 表过多的优化思路

当 MySQL 查询涉及大量表 JOIN 时&#xff0c;性能会显著下降。以下是优化思路和简易实现方法&#xff1a; 一、核心优化思路 减少 JOIN 数量 数据冗余&#xff1a;添加必要的冗余字段&#xff08;如订单表直接存储用户名&#xff09;合并表&#xff1a;将频繁关联的小表合并成…...

三分算法与DeepSeek辅助证明是单峰函数

前置 单峰函数有唯一的最大值&#xff0c;最大值左侧的数值严格单调递增&#xff0c;最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值&#xff0c;最小值左侧的数值严格单调递减&#xff0c;最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...