读取txt文件时,提示异常:

文件“..\Log\all_info.txt”正由另一进程使用,因此该进程无法访问此文件

原因:

日志文件通过lognet生成的日志文件(​​C#使用log4net记录日志​​),自动任务一直在进行,文件流没有关闭。

所以获取文件内容时,会提示进程被占用。

尝试方案:

通过System.IO.File读取 -- ReadAllLines/ReadAllText等方法,报错进程占用异常

var

通过FileStream读取数据

1     using (FileStream fsRead = new FileStream(_filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))
2 {
3 int fsLen = (int)fsRead.Length;
4 byte[] heByte = new byte[fsLen];
5 fsRead.Read(heByte, 0, heByte.Length);
6 string myStr = System.Text.Encoding.UTF8.GetString(heByte);
7

测试:OK

重点在FileShare这个参数,FileShare.ReadWrite 允许打开文件后,依然可以进行读取。

C# 只读模式读取txt文件内容_日志文件

也使用StringBuilder读取行数据,通过FileStream和StreamReader处理数据流:

1 public static string ReadTextFromFileWithReadOnlyMode(string filename)
2 {
3 string content;
4 using (FileStream fs = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite))
5 {
6 using (StreamReader sr = new StreamReader(fs, System.Text.Encoding.Default))
7 {
8 StringBuilder sb = new StringBuilder();
9 while (!sr.EndOfStream)
10 {
11 sb.AppendLine(sr.ReadLine() + "<br>");
12 }
13 content = sb.ToString();
14 }
15 }
16 return content;
17

 

作者:​​唐宋元明清2188​