C#利用缓存分块读写大文件
作者:Hold人民币
这篇文章主要为大家详细介绍了C#利用缓存分块读写大文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
C#利用缓存分块读写大文件,供大家参考,具体内容如下
在日常生活中,可能会遇到大文件的读取,不论是什么格式,按照储存文件的格式读取大文件,就会在Buffer中看到相关的文件头合内容, 以一次.txt文件存取为例。
using System.IO;
首先创建demo文件,此处文件大小没关系,只是演示
private void button2_Click(object sender, EventArgs e) { using (FileStream fsWrite = new FileStream(@"D:\1.txt", FileMode.Append)) { string temp = ""; for (int i = 0; i < 10000;i++ ) { temp += i.ToString()+"/t"; } byte [] m = System.Text.Encoding.UTF8.GetBytes (temp); fsWrite.Write(m, 0, temp.Length); } }
读取创建的文件
private void Readtxt() { using (FileStream fsRead = new FileStream(@"d:\2.txt,FileMode.Open")) { //剩余文件内容长度 long leftLength = fsRead.Length; //buffersize int buffersize = 1024; //创建缓存数组 byte[] buffer = new byte[buffersize]; int rNum = 0; int FileStart = 0; while(leftLength > 0) { //设置文件流的读取位置 fsRead.Position = FileStart ; if (leftLength < buffersize) { rNum = fsRead.Read(buffer, 0, Convert.ToInt32(leftLength)); } else { rNum = fsRead.Read(buffer, 0, maxLength); } if (rNum == 0) { break; } fileStart += rNum; leftLength -= rNum; //字节转换 string msg = System.Text.Encoding.UTF8.GetString(buffer);// byte[] myByte = System.Text.Encoding.UTF8.GetBytes(msg);// //写入文件 using (FileStream fsWrite = new FileStream(@"d:\2.txt, FileMode.Append))//处理完成再追加 { fsWrite.Write(myByte, 0, myByte.Length); } } fsRead.Close(); } }
写入文件后期,还牵扯到数据的拼接与处理
个人感觉,数据如果要按照一定格式拼接,可以通过改变每次读取的位置,来处理。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。