亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

用C#寫的讀寫CSV文件

2019-11-17 02:19:28
字體:
來源:轉載
供稿:網友
用C#寫的讀寫CSV文件

用C#寫的讀取CSV文件的源代碼

CSV文件的格子中包含逗號,引號,換行等,都能輕松讀取,而且可以把數據轉化成DATATABLE格式

using System;using System.Text;using System.Collections;using System.IO;using System.Data;using System.Text.RegularExPRessions;using System.Diagnostics; namespace CsvLib{ #region 類說明信息  /// <summary> ///  <DL> ///  <DT><b>讀CSV文件類,讀取指定的CSV文件,可以導出DataTable</b></DT> ///   <DD> ///    <UL>  ///    </UL> ///   </DD> ///  </DL> ///  <Author>yangzhihong</Author>    ///  <CreateDate>2006/01/16</CreateDate> ///  <Company></Company> ///  <Version>1.0</Version> /// </summary> #endregion public class CsvStreamReader {  private  ArrayList  rowAL;        //行鏈表,CSV文件的每一行就是一個鏈  private  string  fileName;       //文件名   private  Encoding encoding;       //編碼   public CsvStreamReader()  {   this.rowAL = new ArrayList();      this.fileName = "";   this.encoding = Encoding.Default;  }   /// <summary>  ///  /// </summary>  /// <param name="fileName">文件名,包括文件路徑</param>  public CsvStreamReader(string fileName)  {   this.rowAL = new ArrayList();       this.fileName = fileName;   this.encoding = Encoding.Default;   LoadCsvFile();  }   /// <summary>  ///  /// </summary>  /// <param name="fileName">文件名,包括文件路徑</param>  /// <param name="encoding">文件編碼</param>  public CsvStreamReader(string fileName,Encoding encoding)  {   this.rowAL = new ArrayList();     this.fileName = fileName;   this.encoding = encoding;   LoadCsvFile();  }   /// <summary>  /// 文件名,包括文件路徑  /// </summary>  public string FileName  {   set   {    this.fileName = value;    LoadCsvFile();   }  }   /// <summary>  /// 文件編碼  /// </summary>   public Encoding FileEncoding  {   set   {    this.encoding = value;   }  }   /// <summary>  /// 獲取行數  /// </summary>  public int RowCount  {   get   {    return this.rowAL.Count;   }  }   /// <summary>  /// 獲取列數  /// </summary>  public int ColCount  {   get   {    int maxCol;     maxCol = 0;    for (int i = 0;i<this.rowAL.Count;i++)    {     ArrayList colAL = (ArrayList) this.rowAL[i];      maxCol = (maxCol > colAL.Count)?maxCol:colAL.Count;    }     return maxCol;   }  }    /// <summary>  /// 獲取某行某列的數據   /// row:行,row = 1代表第一行   /// col:列,col = 1代表第一列    /// </summary>  public string this[int row,int col]  {   get   {       //數據有效性驗證     CheckRowValid(row);    CheckColValid(col);    ArrayList colAL = (ArrayList) this.rowAL[row-1];     //如果請求列數據大于當前行的列時,返回空值     if (colAL.Count < col)    {     return "";    }                     return colAL[col-1].ToString();       }  }    /// <summary>  /// 根據最小行,最大行,最小列,最大列,來生成一個DataTable類型的數據   /// 行等于1代表第一行   /// 列等于1代表第一列   /// maxrow: -1代表最大行  /// maxcol: -1代表最大列  /// </summary>  public DataTable this[int minRow,int maxRow,int minCol,int maxCol]  {   get   {    //數據有效性驗證     CheckRowValid(minRow);    CheckMaxRowValid(maxRow);    CheckColValid(minCol);    CheckMaxColValid(maxCol);    if (maxRow == -1)    {     maxRow = RowCount;    }    if (maxCol == -1)    {     maxCol = ColCount;    }    if (maxRow < minRow)    {     throw new Exception("最大行數不能小于最小行數");    }    if (maxCol < minCol)    {     throw new Exception("最大列數不能小于最小列數");    }    DataTable csvDT = new DataTable();    int   i;    int   col;    int   row;     //增加列     for (i = minCol;i <= maxCol;i++)    {     csvDT.Columns.Add(i.ToString());    }    for (row = minRow;row <= maxRow;row++)    {     DataRow csvDR = csvDT.NewRow();      i = 0;     for (col = minCol;col <=maxCol;col++)     {      csvDR[i] = this[row,col];      i++;     }     csvDT.Rows.Add(csvDR);    }     return csvDT;   }  }    /// <summary>  /// 檢查行數是否是有效的   /// </summary>  /// <param name="col"></param>    private void CheckRowValid(int row)  {   if (row <= 0)   {    throw new Exception("行數不能小于0");       }    if (row > RowCount)   {    throw new Exception("沒有當前行的數據");      }    }   /// <summary>  /// 檢查最大行數是否是有效的   /// </summary>  /// <param name="col"></param>    private void CheckMaxRowValid(int maxRow)  {   if (maxRow <= 0 && maxRow != -1)   {    throw new Exception("行數不能等于0或小于-1");       }    if (maxRow > RowCount)   {    throw new Exception("沒有當前行的數據");      }    }   /// <summary>  /// 檢查列數是否是有效的   /// </summary>  /// <param name="col"></param>    private void CheckColValid(int col)  {   if (col <= 0)   {    throw new Exception("列數不能小于0");       }    if (col > ColCount)   {    throw new Exception("沒有當前列的數據");      }  }   /// <summary>  /// 檢查檢查最大列數是否是有效的   /// </summary>  /// <param name="col"></param>    private void CheckMaxColValid(int maxCol)  {   if (maxCol <= 0 && maxCol != -1)   {    throw new Exception("列數不能等于0或小于-1");       }    if (maxCol > ColCount)   {    throw new Exception("沒有當前列的數據");      }  }   /// <summary>  /// 載入CSV文件  /// </summary>  private void LoadCsvFile()  {   //對數據的有效性進行驗證    if (this.fileName == null)   {    throw new Exception("請指定要載入的CSV文件名");   }   else if (!File.Exists(this.fileName))   {    throw new Exception("指定的CSV文件不存在");   }   else   {   }   if (this.encoding == null)   {    this.encoding = Encoding.Default;   }    StreamReader sr = new StreamReader(this.fileName,this.encoding);    string   csvDataLine;       csvDataLine = "";   while (true)   {    string fileDataLine;     fileDataLine = sr.ReadLine();    if (fileDataLine == null)    {     break;    }    if (csvDataLine == "")    {     csvDataLine = fileDataLine;//GetDeleteQuotaDataLine(fileDataLine);    }    else    {     csvDataLine += "/r/n" + fileDataLine;//GetDeleteQuotaDataLine(fileDataLine);    }    //如果包含偶數個引號,說明該行數據中出現回車符或包含逗號    if (!IfOddQuota(csvDataLine))    {     AddNewDataLine(csvDataLine);     csvDataLine = "";    }   }              sr.Close();   //數據行出現奇數個引號   if (csvDataLine.Length > 0)   {    throw new Exception("CSV文件的格式有錯誤");   }  }   /// <summary>  /// 獲取兩個連續引號變成單個引號的數據行  /// </summary>  /// <param name="fileDataLine">文件數據行</param>  /// <returns></returns>  private string GetDeleteQuotaDataLine(string fileDataLine)  {   return fileDataLine.Replace("/"/"","/"");  }   /// <summary>  /// 判斷字符串是否包含奇數個引號  /// </summary>  /// <param name="dataLine">數據行</param>  /// <returns>為奇數時,返回為真;否則返回為假</returns>  private bool IfOddQuota(string dataLine)  {   int  quotaCount;   bool oddQuota;    quotaCount = 0;   for (int i = 0;i < dataLine.Length;i++)   {    if (dataLine[i] == '/"')    {     quotaCount++;    }   }    oddQuota = false;   if (quotaCount % 2 == 1)   {    oddQuota = true;   }       return oddQuota;  }   /// <summary>  /// 判斷是否以奇數個引號開始   /// </summary>  /// <param name="dataCell"></param>  /// <returns></returns>  private bool IfOddStartQuota(string dataCell)  {   int  quotaCount;   bool oddQuota;    quotaCount = 0;   for (int i = 0;i < dataCell.Length;i++)   {    if (dataCell[i] == '/"')    {     quotaCount++;    }    else    {     break;    }   }    oddQuota = false;   if (quotaCount % 2 == 1)   {    oddQuota = true;   }       return oddQuota;  }   /// <summary>  /// 判斷是否以奇數個引號結尾  /// </summary>  /// <param name="dataCell"></param>  /// <returns></returns>  private bool IfOddEndQuota(string dataCell)  {   int  quotaCount;   bool oddQuota;    quotaCount = 0;   for (int i = dataCell.Length -1;i >= 0;i--)   {    if (dataCell[i] == '/"')    {     quotaCount++;    }    else    {     break;    }   }    oddQuota = false;   if (quotaCount % 2 == 1)   {    oddQuota = true;   }       return oddQuota;  }   /// <summary>  /// 加入新的數據行   /// </summary>  /// <param name="newDataLine">新的數據行</param>  private void AddNewDataLine(string newDataLine)  {   Debug.WriteLine("NewLine:" + newDataLine);    //return;    ArrayList colAL = new ArrayList();   string[] dataArray = newDataLine.Split(',');   bool  oddStartQuota;       //是否以奇數個引號開始
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
热久久这里只有精品| 久久久97精品| 日韩成人在线视频观看| 国产日产亚洲精品| 国产精品夫妻激情| 九九久久久久99精品| 国产精品偷伦视频免费观看国产| 成人春色激情网| 日韩在线中文字| 欧美电影免费观看高清完整| 91香蕉国产在线观看| 国产美女精彩久久| 欧美激情一区二区三区高清视频| 91综合免费在线| 欧美电影免费观看| 91精品国产九九九久久久亚洲| 欧美精品video| 黄色一区二区在线观看| 在线精品高清中文字幕| 欧美国产视频日韩| 日韩精品视频免费| 成人在线精品视频| 欧美成人一区在线| 亚洲一区国产精品| 日韩在线欧美在线国产在线| 日韩电影中文字幕在线| 55夜色66夜色国产精品视频| 亚洲va久久久噜噜噜久久天堂| 亚洲精品aⅴ中文字幕乱码| 成人一区二区电影| 一区国产精品视频| 亚洲欧洲在线观看| 亚洲欧美第一页| 日韩国产欧美精品在线| 精品中文字幕视频| 国产91色在线| 亚洲国产精品久久精品怡红院| 欧美性一区二区三区| 久久精品久久久久电影| 国产在线视频2019最新视频| 国产精品久久久久久久久久久不卡| 亚洲精品国产美女| 性欧美激情精品| 精品色蜜蜜精品视频在线观看| 亚洲成人免费网站| 国产欧美日韩视频| 国产精品第一区| 日韩免费在线免费观看| 久久好看免费视频| 国产午夜精品免费一区二区三区| 午夜精品久久久久久久男人的天堂| 日韩精品久久久久久久玫瑰园| 精品久久久久久久久久久久久| 91精品国产乱码久久久久久蜜臀| 91美女片黄在线观| 国产精品高潮呻吟久久av黑人| 久久久久久久久久久网站| 在线午夜精品自拍| 国产成人精品久久亚洲高清不卡| 精品亚洲男同gayvideo网站| 亚洲国产欧美一区二区三区同亚洲| 久久免费精品日本久久中文字幕| 色播久久人人爽人人爽人人片视av| 欧美日韩另类字幕中文| 欧美与黑人午夜性猛交久久久| 大量国产精品视频| 国产综合福利在线| 国产成人精品久久亚洲高清不卡| 国产精品亚洲欧美导航| 日韩免费在线播放| 亚洲电影免费观看高清完整版在线| 国产精品视频永久免费播放| 亚洲精品美女久久久| 亚洲精品狠狠操| 亚洲国产精品小视频| 久久久久中文字幕2018| 在线看日韩欧美| 欧美国产日韩免费| 中文字幕9999| 欧亚精品在线观看| 在线观看日韩av| 亚洲欧洲日本专区| 国产亚洲精品va在线观看| 亚洲已满18点击进入在线看片| 国色天香2019中文字幕在线观看| 成人免费激情视频| 亚洲精品一区久久久久久| 国产视频福利一区| 久久久噜久噜久久综合| 午夜欧美大片免费观看| 午夜精品福利视频| 国产精品一区二区三区久久久| 日本一本a高清免费不卡| 日本成人免费在线| 国产一区二区三区日韩欧美| 日韩小视频在线观看| 亚洲伊人第一页| 国产精品黄页免费高清在线观看| 国产一级揄自揄精品视频| 国产精品免费小视频| 国精产品一区一区三区有限在线| 亚洲成成品网站| 亚洲精品视频中文字幕| 国产mv久久久| 中文字幕精品久久久久| 神马久久久久久| 最近2019年好看中文字幕视频| 欧美精品18videos性欧美| 91精品国产777在线观看| 亚洲天堂av在线播放| 国产在线观看精品| 久久久精品视频在线观看| 国产精品一区av| 91视频免费网站| 久久久久中文字幕| 九九九久久久久久| 欧美成人在线免费| 亚洲成人1234| 亚洲国产欧美一区二区三区同亚洲| 成人伊人精品色xxxx视频| 亚洲成人久久网| 日韩成人av网址| 亚洲色图50p| 国产欧美一区二区| 国产在线观看91精品一区| 欧美激情中文字幕在线| xxx成人少妇69| 国产精品久久97| 尤物99国产成人精品视频| 国产精品视频公开费视频| 久久精品一偷一偷国产| 久久视频国产精品免费视频在线| 一区二区三区日韩在线| 国产精品精品久久久| 久久久久久国产三级电影| 国产91网红主播在线观看| 欧美大尺度激情区在线播放| 97在线视频免费看| 精品国偷自产在线| 欧美天天综合色影久久精品| 欧美小视频在线观看| 日韩美女视频在线观看| 中文国产亚洲喷潮| 精品欧美激情精品一区| 久久艹在线视频| 国产一区二区视频在线观看| 欧美情侣性视频| 中文在线资源观看视频网站免费不卡| 91精品视频在线播放| 国产精品第1页| 色综合久久悠悠| 日韩电影免费观看中文字幕| 国产剧情日韩欧美| 欧美黑人国产人伦爽爽爽| 亚洲一区亚洲二区| 欧美久久精品一级黑人c片| 亚洲最新av在线网站| 久久久久久免费精品| 在线播放日韩欧美| 亚洲精品国产精品国自产在线| 亚洲欧美在线x视频| 亚洲精品乱码久久久久久按摩观| 欧美日韩在线一区| 久久久天堂国产精品女人|