C#实现一个简单实用的TXT文本操作及日志框架详解

前言

首先先介绍一下这个项目,该项目实现了文本写入及读取,日志写入指定文件夹或默认文件夹,日志数量控制,单个日志大小控制,通过约定的参数让用户可以用更少的代码解决问题。

1.读取文本文件方法

使用:JIYUWU.TXT.TXTHelper.ReadToString(“文件物理路径”)

public static string ReadToString(string path)
 {
  try
  {
  LogLock.EnterReadLock();
  StreamReader sr = new StreamReader(path, Encoding.UTF8);
  StringBuilder sb = new StringBuilder();
  string line;
  while ((line = sr.ReadLine()) != null)
  {
   sb.AppendLine(line.ToString());
  }
  sr.Close();
  sr.Dispose();
  return sb.ToString();
  }
  catch (IOException e)
  {
  Console.WriteLine(e.ToString());
  return null;
  }
  finally
  {
  LogLock.ExitReadLock();
  }
 }

实现解析:

(1.为防止任务读取当我们进行读取时需要添加读取锁保证可以依次读取,否则可能出现被占用异常。

(2.创建读取流StreamReader(注意:由于会出现乱码这里要改一下把默认改为Encoding.UTF8),依次读取每一行。

(3.读取完成释放资源。并解锁。

2.写入文本文件方法

(1.创建文本并写入

使用:JIYUWU.TXT.TXTHelper.CreateWrite(“文件物理路径”,“文本内容”)

public static bool CreateWrite(string path, string context)
 {
  bool b = false;
  try
  {
  LogLock.EnterWriteLock();
  FileStream fs = new FileStream(path, FileMode.Create);
  //获得字节数组
  byte[] data = System.Text.Encoding.Default.GetBytes(context);
  //开始写入
  fs.Write(data, 0, data.Length);
  //清空缓冲区、关闭流
  fs.Flush();
  fs.Close();
  return b;
  }
  catch (Exception ex)
  {
  Console.WriteLine(ex.ToString());
  return b;
  }
  finally
  {
  LogLock.ExitWriteLock();
  }
 }

(2.在文本文件末尾追加写入

使用:JIYUWU.TXT.TXTHelper.WriteAppend(“文件物理路径”,“文本内容”)

public static bool WriteAppend(string path, string context)
 {
  bool b = false;
  try
  {
  LogLock.EnterWriteLock();
  FileStream fs = new FileStream(path, FileMode.Append);
  StreamWriter sw = new StreamWriter(fs);
  //开始写入
  sw.Write(context);
  //清空缓冲区
  sw.Flush();
  //关闭流
  sw.Close();
  fs.Close();
  return b;
  }
  catch (Exception ex)
  {
  Console.WriteLine(ex.ToString());
  return b;
  }
  finally
  {
  LogLock.ExitWriteLock();
  }
 }

(3.自动判断换行追加或创建文本

使用:JIYUWU.TXT.TXTHelper.CreateOrWriteAppendLine(“文件物理路径”,“文本内容”)

public static bool CreateOrWriteAppendLine(string path, string context)
 {
  bool b = false;
  try
  {
  LogLock.EnterWriteLock();
  if (!File.Exists(path))
  {
   FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write);
   StreamWriter sw = new StreamWriter(fs);
   long fl = fs.Length;
   fs.Seek(fl, SeekOrigin.End);
   sw.WriteLine(context);
   sw.Flush();
   sw.Close();
   fs.Close();
   b = true;
  }
  else
  {
   FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Write);
   StreamWriter sw = new StreamWriter(fs);
   long fl = fs.Length;
   fs.Seek(fl, SeekOrigin.Begin);
   sw.WriteLine(context);
   sw.Flush();
   sw.Close();
   fs.Close();
   b = true;
  }
  return b;
  }
  catch (Exception ex)
  {
  Console.WriteLine(ex.ToString());
  return b;
  }
  finally
  {
  LogLock.ExitWriteLock();
  }
 }

实现解析:

(1)为防止多任务读取当我们进行读取时需要添加读取锁保证可以依次写入,否则可能出现被占用异常。

(2)创建文本流FileStream及写入流StreamWriter,直接进行数据写入。

(3)读取完成释放资源。并解锁。

3.写入日志

使用:JIYUWU.TXT.TXTHelper.WriteLog(“文本内容”,“单个文件大小(选填默认1M)”,“目录下文件数量(选填默认20个)”,“输出目录(选填默认bin文件下)”)

public static void WriteLog(string content, int fileSize = 1, int fileCount = 20, string filePath = "")
 {
  try
  {
  if (!string.IsNullOrWhiteSpace(filePath))
  {
   logPath = filePath;
  }
  LogLock.EnterWriteLock();
  logPath = logPath.Replace("file:\\", "");//这里为了兼容webapi的情况
  string dataString = DateTime.Now.ToString("yyyy-MM-dd");
  string path = logPath + "\\MyLog";
  if (!Directory.Exists(path))
  {
   Directory.CreateDirectory(path);
   path += "\\";
   path += DateTime.Now.ToString("yyyy-MM-dd") + ".txt";
   FileStream fs = new FileStream(path, FileMode.Create);
   fs.Close();
  }
  else
  {
   int x = System.IO.Directory.GetFiles(path).Count();
   path += "\\";
   Dictionary<string, DateTime> fileCreateDate = new Dictionary<string, DateTime>();
   string[] filePathArr = Directory.GetFiles(path, "*.txt", SearchOption.TopDirectoryOnly);
   if (filePathArr.Length == 0)
   {
   string sourceFilePath = path;
   path += DateTime.Now.ToString("yyyy-MM-dd") + ".txt";
   FileStream fs = new FileStream(path, FileMode.Create);
   fs.Close();
   filePathArr = Directory.GetFiles(sourceFilePath, "*.txt", SearchOption.TopDirectoryOnly);
   }
   for (int i = 0; i < filePathArr.Length; i++)
   {
   FileInfo fi = new FileInfo(filePathArr[i]);
   fileCreateDate[filePathArr[i]] = fi.CreationTime;
   }
   fileCreateDate = fileCreateDate.OrderBy(f => f.Value).ToDictionary(f => f.Key, f => f.Value);
   FileInfo fileInfo = new FileInfo(fileCreateDate.Last().Key);
   if (fileInfo.Length < 1024 * 1024 * fileSize)
   {
   path = fileCreateDate.Last().Key;
   }
   else
   {
   path += DateTime.Now.ToString("yyyy-MM-dd") + ".txt";
   FileStream fs = new FileStream(path, FileMode.Create);
   fs.Close();
   }
   if (x > fileCount)
   {
   File.Delete(fileCreateDate.First().Key);
   }

  }
  FileStream fs2 = new FileStream(path, FileMode.Open, FileAccess.Write);
  StreamWriter sw = new StreamWriter(fs2);
  long fl = fs2.Length;
  fs2.Seek(fl, SeekOrigin.Begin);
  sw.WriteLine(DateTime.Now.ToString("hh:mm:ss") + "---> " + content);
  sw.Flush();
  sw.Close();
  fs2.Close();
  }
  catch (Exception ex)
  {
  Console.WriteLine(ex.ToString());
  }
  finally
  {
  LogLock.ExitWriteLock();
  }

 }

实现解析(以全部默认参数为例说明):

(1.为防止多任务进行操作,于是对文档加一个写入锁,否则可能出现被占用异常。

(2.检测文件目录是否已存在,不存在则创建目录并创建日志文件,存在就判断文件数量和大小,文件大小超过设置的值或默认值就新建一个文本,文件数量超过默认值或设置值就删除最早的一个文件。

(3.写入到指定文件。

(4.完成释放资源。并解锁。

项目框架就介绍到这里吧,后期还会将功能扩展,不多说了源码地址:

http://xiazai.jb51.net/201807/yuanma/c-txt-log_jb51.rar (可能存在没有测到的bug,出现的问题可以反馈给我,谢谢您的支持)。

问题汇总:

bug1:程序包中读取txt可能出现乱码,读取流中改一下把默认改为Encoding.UTF8应该就可以了。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。

(0)

相关推荐

  • C#中把日志导出到txt文本的简单实例

    复制代码 代码如下: /// <summary>        /// 打日志        /// </summary>        /// <param name="log"></param> //首先还是要using system.io;             public void Write(ArrayList log)            {                      //将文件保存在桌面,文件名称为当前

  • C#实现将程序运行信息写入日志的方法

    本文实例讲述了C#实现将程序运行信息写入日志的方法.分享给大家供大家参考.具体如下: 1.LogManager类 class LogManager { static object locker = new object(); /// <summary> /// 重要信息写入日志 /// </summary> /// <param name="logs">日志列表,每条日志占一行</param> public static void Wri

  • C#记录消息到日志文件的方法

    本文实例讲述了C#记录消息到日志文件的方法.分享给大家供大家参考.具体实现方法如下: public void LogMessageToFile(string msg) { System.IO.StreamWriter sw = System.IO.File.AppendText("log.txt"); try { string logLine = System.String.Format("{0:G}: {1}.", System.DateTime.Now, msg

  • c#实现把异常写入日志示例(异常日志)

    将异常写到日志文件中,可以在调试程序的时候知道程序发生过哪些异常,并且可以知道异常发生的位置.这点对需要进行长时间运行并调试的程序尤为有效. 复制代码 代码如下: /// <summary>/// 将异常打印到LOG文件/// </summary>/// <param name="ex">异常</param>/// <param name="LogAddress">日志文件地址</param>p

  • C#实现写系统日志的方法

    本文实例讲述了C#实现写系统日志的方法.分享给大家供大家参考.具体实现方法如下: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Diagnostics; namespace ConsoleApp { /// <summary> /// 系统日志 /// </summary> public class PackSystemEventL

  • C#处理文本文件TXT实例详解

    本文实例讲述了C#处理文本文件TXT的方法.分享给大家供大家参考.具体分析如下: 1. 如何读取文本文件内容: 这里介绍的程序中,是把读取的文本文件,用一个richTextBox组件显示出来.要读取文本文件,必须使用到"StreamReader"类,这个类是由名字空间"System.IO"中定义的.通过"StreamReader"类的"ReadLine()"方法,就可以读取打开数据流当前行 的数据了.下面代码实现的功能就是读取

  • C#写日志类实例

    本文实例讲述了C#写日志类,分享给大家供大家参考. 具体实现方法如下: 复制代码 代码如下: using System; using System.Configuration; using System.IO; using System.Threading; namespace FQDService.Utils {     /// <summary>     /// 写日志类     /// </summary>     public class FileLogger     {

  • C#实现把txt文本数据快速读取到excel中

    今天预实现一功能,将txt中的数据转到excel表中,做为matlab的数据源.搜集一些c#操作excel的程序.步骤如下: 下载一个Microsoft.Office.Interop.Excel.dll   在项目中引用. 编写代码如下: string path = "c://date//xyu.txt"; StreamReader sr = new StreamReader(path); string strLine = sr.ReadLine(); int rowNum = 1;

  • C#实现将日志写入文本文件的方法

    本文实例讲述了C#实现将日志写入文本文件的方法.分享给大家供大家参考.具体如下: 这里传入的参数是 要写的内容 using System.IO; public static void WriteLog(string strLog) { string sFilePath="d:\\"+DateTime.Now.ToString("yyyyMM"); string sFileName = "rizhi" + DateTime.Now.ToString

  • C#实现一个简单实用的TXT文本操作及日志框架详解

    前言 首先先介绍一下这个项目,该项目实现了文本写入及读取,日志写入指定文件夹或默认文件夹,日志数量控制,单个日志大小控制,通过约定的参数让用户可以用更少的代码解决问题. 1.读取文本文件方法 使用:JIYUWU.TXT.TXTHelper.ReadToString("文件物理路径") public static string ReadToString(string path) { try { LogLock.EnterReadLock(); StreamReader sr = new

  • 一天一个shell命令 linux文本操作系列-diff命令详解

    这又是一个文件比较命令,熟练掌握会节省你很多工作.还记得comm命令吗?diff比他更加复杂,好用,不仅能比较文件,还能比较目录. 当一个文件有多个版本时候,或者更多复杂的文件,目录比较时,你会期望有一个比comm更有用的命令,diff正是为此而生. 全称:different file 实例: 文件1: v1.txt 复制代码 代码如下: hello   world v1_echo   v1_diff   v1_comm  shell is easy! 文件2: v2.txt 复制代码 代码如下

  • 一天一个shell命令 linux文本操作系列-wc命令详解

    全称 wc是一个用于统计的工具,全拼为:Word Count(单词统计) 实例: 1. 统计行数 $wc –l file 2. 统计单词数 $wc –w file 3. 统计字符数 $wc –c file 4. 统计流中的字符数 $echo –n 1234 | wc –c 输出:4 解读--help 用法:wc [选项]... [文件]... 或:wc [选项]... --files0-from=F 打印每行的换行符,单词,字节的数量,如果多于一个文件,则打印每个总行数.如果没有文件,或者文件位

  • 一天一个shell命令 linux文本操作系列-tree命令详解

    tree命令是以图形化的树结构打印文件和目录的主角.通常linux发行版本中并没有包括这个命令.你需要用包管理器自行安装. 实例: 1. tree 打印当前目录下所有文件 2. tree –p ${dir} 打印dir目录下所有文件,以及他们的权限 3. tree –h ${dir} 打印dir目录下所有文件,以及适读的大小 4. tree path –P "*.sh" 打印所有.sh结尾的文件 5. tree path –H http://localhost –o out.html

  • 一天一个shell命令 linux文件内容操作系列-cat命令详解

    注:在awk命令之后,没有太多复杂命令,都是一些基础命令. 说明: cat,是单词 concatenate 的缩写, 把文件的内容输出到stdout.当与重定向操作符 (> 或 >>结合使用时, 一般都是用来将多个文件连接起来. 用法: 1. $cat file1 file2 file3 2. 不仅可以从文件中读取内容并且拼接,还能从标准输入流中读取 例如:$echo 'some content' |  cat - file.txt 解释:这里的 - 就代表了 'some content

  • K8S 实用工具之合并多个kubeconfig实现详解

    目录 开篇 解决方案 方案一:KUBECONFIG 环境变量指向多个文件 方案二:flatten 方案三:kubectl 插件 konfig 实用工具:krew 实用工具:konfig 总结 开篇 磨刀不误砍柴工 工欲善其事必先利其器 K8S 集群规模,有的公司倾向于少量大规模 K8S 集群,也有的公司会倾向于大量小规模的 K8S 集群. 如果是第二种情况,是否有一个简单的 kubectl 命令来获取一个 kubeconfig 文件并将其合并到 ~/.kube/config 文件作为一个额外的上

  • 简单了解Java方法的定义和使用实现详解

    这篇文章主要介绍了简单了解Java方法的定义和使用实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 1.概念 Java语言中的"方法"(Method)在其他语言当中也可能被称为"函数"(Function).对于一些复杂的代码逻辑,如果希望重复使用这些代码,并且做到"随时任意使用",那么就可以将这些代码放在一个大括号"{}"当中,并且起一个名字.使用代码的时候,直接找到名

  • Linux文本查看命令及其选项详解(cat,head,tail)

    linux系统内置命令可以通过以下两种方式查询:"cat --help" 或者"man cat". cat命令的常用选项和官方解释如下: cat file_name 显示文件全部内容 cat -b file_name 显示文件非空行内容 cat -E file_name 在文件每行末尾显示$,常用于管道功能 cat -n file_name 显示内容和行号 Usage: cat [OPTION]... [FILE]... Concatenate FILE(s) to

  • C#设置或验证PDF文本域格式的方法详解

    目录 概述 引入dll 代码(C#/VB.NET) 概述 PDF中的文本域可以通过设置不同格式,用于显示数字.货币.日期.时间.邮政编码.电话号码和社保号等等.Adobe Acrobat提供了许多固定的JavaScripts用来设置和验证文本域的格式,如:AFNumber_Format(2, 0, 0, 0, "$", true)和AFNumber_Keystroke(2, 0, 0, 0, "$", true).Format后缀的script是用来设置文本域显示的

  • IOS 简单的本地json格式文件解析的实例详解

    IOS 简单的本地json格式文件解析的实例详解 ljweibo.json文件 { "data":[{ "name" : "孙悟空", "content" : "7月12日的国务院常务会议上,李克强明确要求,要将已审议的<快递条例(草案)>向社会公开征求意见.在会上,总理说了这么一段话:"几年前,快递业刚刚开始发展的时候,有些城市不允许快递存在,理由是影响市容整洁,快递员骑的摩的也不允许停放.但

随机推荐