讀取txt文件時,提示異常:
文件“..\Log\all_info.txt”正由另一進程使用,因此該進程無法訪問此文件
原因:
日志文件通過lognet生成的日志文件(C#使用log4net記錄日志),自動任務一直在進行,文件流沒有關閉。
所以獲取文件內容時,會提示進程被占用。
嘗試方案:
通過System.IO.File讀取 -- ReadAllLines/ReadAllText等方法,報錯進程占用異常
var fileContent = File.ReadAllText(_filename);
通過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 允許打開文件后,依然可以進行讀取。
也使用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 }