服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - C#实现一个简单实用的TXT文本操作及日志框架详解

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

2022-02-27 15:45殷慈航 C#

这篇文章主要给大家介绍了关于利用C#如何实现一个简单实用的TXT文本操作及日志框架的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们一起来看看吧

前言

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

1.读取文本文件方法

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
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(“文件物理路径”,“文本内容”)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
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(“文件物理路径”,“文本内容”)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
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(“文件物理路径”,“文本内容”)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
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文件下)”)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
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.完成释放资源。并解锁。

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

c-txt-log.rar (可能存在没有测到的bug,出现的问题可以反馈给我,谢谢您的支持)。

问题汇总:

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

总结

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

原文链接:https://www.cnblogs.com/jiyuwu/archive/2018/07/28/9383193.html

延伸 · 阅读

精彩推荐
  • C#SQLite在C#中的安装与操作技巧

    SQLite在C#中的安装与操作技巧

    SQLite,是一款轻型的数据库,用于本地的数据储存。其优点有很多,下面通过本文给大家介绍SQLite在C#中的安装与操作技巧,感兴趣的的朋友参考下吧...

    蓝曈魅11162022-01-20
  • C#三十分钟快速掌握C# 6.0知识点

    三十分钟快速掌握C# 6.0知识点

    这篇文章主要介绍了C# 6.0的相关知识点,文中介绍的非常详细,通过这篇文字可以让大家在三十分钟内快速的掌握C# 6.0,需要的朋友可以参考借鉴,下面来...

    雨夜潇湘8272021-12-28
  • C#深入理解C#的数组

    深入理解C#的数组

    本篇文章主要介绍了C#的数组,数组是一种数据结构,详细的介绍了数组的声明和访问等,有兴趣的可以了解一下。...

    佳园9492021-12-10
  • C#如何使用C#将Tensorflow训练的.pb文件用在生产环境详解

    如何使用C#将Tensorflow训练的.pb文件用在生产环境详解

    这篇文章主要给大家介绍了关于如何使用C#将Tensorflow训练的.pb文件用在生产环境的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴...

    bbird201811792022-03-05
  • C#利用C#实现网络爬虫

    利用C#实现网络爬虫

    这篇文章主要介绍了利用C#实现网络爬虫,完整的介绍了C#实现网络爬虫详细过程,感兴趣的小伙伴们可以参考一下...

    C#教程网11852021-11-16
  • C#C#设计模式之Strategy策略模式解决007大破密码危机问题示例

    C#设计模式之Strategy策略模式解决007大破密码危机问题示例

    这篇文章主要介绍了C#设计模式之Strategy策略模式解决007大破密码危机问题,简单描述了策略模式的定义并结合加密解密算法实例分析了C#策略模式的具体使用...

    GhostRider10972022-01-21
  • C#C#微信公众号与订阅号接口开发示例代码

    C#微信公众号与订阅号接口开发示例代码

    这篇文章主要介绍了C#微信公众号与订阅号接口开发示例代码,结合实例形式简单分析了C#针对微信接口的调用与处理技巧,需要的朋友可以参考下...

    smartsmile20127762021-11-25
  • C#VS2012 程序打包部署图文详解

    VS2012 程序打包部署图文详解

    VS2012虽然没有集成打包工具,但它为我们提供了下载的端口,需要我们手动安装一个插件InstallShield。网上有很多第三方的打包工具,但为什么偏要使用微软...

    张信秀7712021-12-15