如何实现 csv 转换到 datatable.给个思路
1个回答
展开全部
publicclassCSVFileHelper{//////将DataTable中数据写入到CSV文件中//////提供保存数据的DataTable///CSV的文件路径publicstaticvoidSaveCSV(DataTabledt,stringfullPath){FileInfofi=newFileInfo(fullPath);if(!fi.Directory.Exists){fi.Directory.Create();}FileStreamfs=newFileStream(fullPath,System.IO.FileMode.Create,System.IO.FileAccess.Write);//StreamWritersw=newStreamWriter(fs,System.Text.Encoding.Default);StreamWritersw=newStreamWriter(fs,System.Text.Encoding.UTF8);stringdata="";//写出列名称for(inti=0;i///将CSV文件的数据读取到DataTable中//////CSV文件路径///返回读取了CSV数据的DataTablepublicstaticDataTableOpenCSV(stringfilePath){Encodingencoding=Common.GetType(filePath);//Encoding.ASCII;//DataTabledt=newDataTable();FileStreamfs=newFileStream(filePath,System.IO.FileMode.Open,System.IO.FileAccess.Read);//StreamReadersr=newStreamReader(fs,Encoding.UTF8);StreamReadersr=newStreamReader(fs,encoding);//stringfileContent=sr.ReadToEnd();//encoding=sr.CurrentEncoding;//记录每次读取的一行记录stringstrLine="";//记录每行记录中的各字段内容string[]aryLine=null;string[]tableHead=null;//标示列数intcolumnCount=0;//标示是否是读取的第一行boolIsFirst=true;//逐行读取CSV中的数据while((strLine=sr.ReadLine())!=null){//strLine=Common.ConvertStringUTF8(strLine,encoding);//strLine=Common.ConvertStringUTF8(strLine);if(IsFirst==true){tableHead=strLine.Split(',');IsFirst=false;columnCount=tableHead.Length;//创建列for(inti=0;i0){dt.DefaultView.Sort=tableHead[0]+""+"asc";}sr.Close();fs.Close();returndt;}}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询