日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

c#保存数据格式为.cvs_C#读取csv格式文件的方法

發(fā)布時間:2024/4/14 C# 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c#保存数据格式为.cvs_C#读取csv格式文件的方法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

//讀CSV文件類,讀取指定的CSV文件,可以導出DataTable

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;

}

///

///

///

/// 文件名,包括文件路徑

public CsvStreamReader(string fileName)

{

this.rowAL = new ArrayList();

this.fileName = fileName;

this.encoding = Encoding.Default;

LoadCsvFile();

}

///

///

///

/// 文件名,包括文件路徑

/// 文件編碼

public CsvStreamReader(string fileName, Encoding encoding)

{

this.rowAL = new ArrayList();

this.fileName = fileName;

this.encoding = encoding;

LoadCsvFile();

}

///

/// 文件名,包括文件路徑

///

public string FileName

{

set

{

this.fileName = value;

LoadCsvFile();

}

}

///

/// 文件編碼

///

public Encoding FileEncoding

{

set

{

this.encoding = value;

}

}

///

/// 獲取行數(shù)

///

public int RowCount

{

get

{

return this.rowAL.Count;

}

}

///

/// 獲取列數(shù)

///

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;

}

}

///

/// 獲取某行某列的數(shù)據(jù)

/// row:行,row = 1代表第一行

/// col:列,col = 1代表第一列

///

public string this[int row, int col]

{

get

{

//數(shù)據(jù)有效性驗證

CheckRowValid(row);

CheckColValid(col);

ArrayList colAL = (ArrayList)this.rowAL[row - 1];

//如果請求列數(shù)據(jù)大于當前行的列時,返回空值

if (colAL.Count < col)

{

return "";

}

return colAL[col - 1].ToString();

}

}

///

/// 根據(jù)最小行,最大行,最小列,最大列,來生成一個DataTable類型的數(shù)據(jù)

/// 行等于1代表第一行

/// 列等于1代表第一列

/// maxrow: -1代表最大行

/// maxcol: -1代表最大列

///

public DataTable this[int minRow, int maxRow, int minCol, int maxCol]

{

get

{

//數(shù)據(jù)有效性驗證

CheckRowValid(minRow);

CheckMaxRowValid(maxRow);

CheckColValid(minCol);

CheckMaxColValid(maxCol);

if (maxRow == -1)

{

maxRow = RowCount;

}

if (maxCol == -1)

{

maxCol = ColCount;

}

if (maxRow < minRow)

{

throw new Exception("最大行數(shù)不能小于最小行數(shù)");

}

if (maxCol < minCol)

{

throw new Exception("最大列數(shù)不能小于最小列數(shù)");

}

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;

}

}

///

/// 檢查行數(shù)是否是有效的

///

///

private void CheckRowValid(int row)

{

if (row <= 0)

{

throw new Exception("行數(shù)不能小于0");

}

if (row > RowCount)

{

throw new Exception("沒有當前行的數(shù)據(jù)");

}

}

///

/// 檢查最大行數(shù)是否是有效的

///

///

private void CheckMaxRowValid(int maxRow)

{

if (maxRow <= 0 && maxRow != -1)

{

throw new Exception("行數(shù)不能等于0或小于-1");

}

if (maxRow > RowCount)

{

throw new Exception("沒有當前行的數(shù)據(jù)");

}

}

///

/// 檢查列數(shù)是否是有效的

///

///

private void CheckColValid(int col)

{

if (col <= 0)

{

throw new Exception("列數(shù)不能小于0");

}

if (col > ColCount)

{

throw new Exception("沒有當前列的數(shù)據(jù)");

}

}

///

/// 檢查檢查最大列數(shù)是否是有效的

///

///

private void CheckMaxColValid(int maxCol)

{

if (maxCol <= 0 && maxCol != -1)

{

throw new Exception("列數(shù)不能等于0或小于-1");

}

if (maxCol > ColCount)

{

throw new Exception("沒有當前列的數(shù)據(jù)");

}

}

///

/// 載入CSV文件

///

private void LoadCsvFile()

{

//對數(shù)據(jù)的有效性進行驗證

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);

}

//如果包含偶數(shù)個引號,說明該行數(shù)據(jù)中出現(xiàn)回車符或包含逗號

if (!IfOddQuota(csvDataLine))

{

AddNewDataLine(csvDataLine);

csvDataLine = "";

}

}

sr.Close();

//數(shù)據(jù)行出現(xiàn)奇數(shù)個引號

if (csvDataLine.Length > 0)

{

throw new Exception("CSV文件的格式有錯誤");

}

}

///

/// 獲取兩個連續(xù)引號變成單個引號的數(shù)據(jù)行

///

/// 文件數(shù)據(jù)行

///

private string GetDeleteQuotaDataLine(string fileDataLine)

{

return fileDataLine.Replace("\\"\\"", "\\"");

}

///

/// 判斷字符串是否包含奇數(shù)個引號

///

/// 數(shù)據(jù)行

/// 為奇數(shù)時,返回為真;否則返回為假

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;

}

///

/// 判斷是否以奇數(shù)個引號開始

///

///

///

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;

}

///

/// 判斷是否以奇數(shù)個引號結尾

///

///

///

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;

}

///

/// 加入新的數(shù)據(jù)行

///

/// 新的數(shù)據(jù)行

private void AddNewDataLine(string newDataLine)

{

//System.Diagnostics.Debug.WriteLine("NewLine:" + newDataLine);

return;

ArrayList colAL = new ArrayList();

string[] dataArray = newDataLine.Split(',');

bool oddStartQuota;??????? //是否以奇數(shù)個引號開始

string cellData;

oddStartQuota = false;

cellData = "";

for (int i = 0; i < dataArray.Length; i++)

{

if (oddStartQuota)

{

//因為前面用逗號分割,所以要加上逗號

cellData += "," + dataArray[i];

//是否以奇數(shù)個引號結尾

if (IfOddEndQuota(dataArray[i]))

{

colAL.Add(GetHandleData(cellData));

oddStartQuota = false;

continue;

}

}

else

{

//是否以奇數(shù)個引號開始

if (IfOddStartQuota(dataArray[i]))

{

//是否以奇數(shù)個引號結尾,不能是一個雙引號,并且不是奇數(shù)個引號

if (IfOddEndQuota(dataArray[i]) && dataArray[i].Length > 2 && !IfOddQuota(dataArray[i]))

{

colAL.Add(GetHandleData(dataArray[i]));

oddStartQuota = false;

continue;

}

else

{

oddStartQuota = true;

cellData = dataArray[i];

continue;

}

}

else

{

colAL.Add(GetHandleData(dataArray[i]));

}

}

}

if (oddStartQuota)

{

throw new Exception("數(shù)據(jù)格式有問題");

}

this.rowAL.Add(colAL);

}

///

/// 去掉格子的首尾引號,把雙引號變成單引號

///

///

///

private string GetHandleData(string fileCellData)

{

if (fileCellData == "")

{

return "";

}

if (IfOddStartQuota(fileCellData))

{

if (IfOddEndQuota(fileCellData))

{

return fileCellData.Substring(1, fileCellData.Length - 2).Replace("\\"\\"", "\\""); //去掉首尾引號,然后把雙引號變成單引號

}

else

{

throw new Exception("數(shù)據(jù)引號無法匹配" + fileCellData);

}

}

else

{

//考慮形如""??? """"????? """"""

if (fileCellData.Length > 2 && fileCellData[0] == '\\"')

{

fileCellData = fileCellData.Substring(1, fileCellData.Length - 2).Replace("\\"\\"", "\\""); //去掉首尾引號,然后把雙引號變成單引號

}

}

return fileCellData;

}

}

總結

以上是生活随笔為你收集整理的c#保存数据格式为.cvs_C#读取csv格式文件的方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 黄色片网站免费在线观看 | 欧美三级视频在线观看 | 91污网站 | 综合精品国产 | 性xxxx欧美老肥妇牲乱 | 亚洲黄一区 | 亚洲欧美网 | 免费大片在线观看www | 在线免费视频观看 | 天天躁夜夜躁av天天爽 | 九一天堂| 成年人免费av | 国产美女精品一区二区三区 | 精品一区二区三区四 | 成人性视频sm.| 日本在线观看免费 | 亚洲精品在线免费 | 国产午夜在线播放 | 欧美成人精品欧美一级乱黄 | 国产一级做a | 91天天综合| 日本成人精品视频 | 久久精品在线播放 | 色干干| 欧美精品在线一区 | 国产乱淫av免费 | 国产做受高潮动漫 | 欧美一区在线看 | 日韩欧美亚洲成人 | 国产在线视频二区 | 成都免费高清电影 | 亚洲AV无码一区二区三区少妇 | 狠狠躁夜夜躁人爽 | 亚洲国产日韩欧美 | 国内av网| 国产黄色录像 | 国产一级二级三级精品 | 无码人妻精品一区二区50 | 又骚又黄的视频 | 国产精品亚洲精品 | 久久久久成人精品无码 | 污污的视频在线观看 | 91亚洲精品久久久蜜桃借种 | 国产欧美日韩精品在线 | 永久av网站 | 欧美精品一级二级三级 | 老女人黄色片 | 久久久久成人精品免费播放动漫 | 国产天天操| 久久蜜臀精品av | 亚洲精品高清视频在线观看 | 美女被草网站 | 我的丝袜美腿尤物麻麻 | 蜜桃av噜噜一区二区三区麻豆 | 日本黄色美女视频 | 欧美性猛交xxxx黑人猛交 | 久久久久久久久免费视频 | 91蝌蚪视频在线 | h网站在线观看 | 国产五十路 | 国产精视频 | 久久久精品影院 | 在线免费观看日韩 | 成人黄色在线播放 | 久久久久久国产精品免费播放 | 国产欧美日韩高清 | 日本欧美另类 | 日韩人妻一区 | 九九视频国产 | 国产精品人成在线观看免费 | 91一区 | 免费在线观看成人av | 久久99网 | 蜜桃视频在线观看一区 | 亚洲激情视频在线播放 | eeuss国产一区二区三区 | 中字幕视频在线永久在线观看免费 | 日本大尺度做爰呻吟舌吻 | 欧美精品免费一区二区 | 在线国产视频一区 | 黄色大片视频网站 | 好吊妞视频这里只有精品 | 在线成人av | 蜜臀99久久精品久久久久小说 | 欧美激情一区在线 | 欧美一级成人 | 欧美 亚洲 另类 偷偷 自拍 | 欧美在线免费观看视频 | 操三八男人的天堂 | 男女啪啪免费看 | 欧美日韩经典 | 不卡视频在线播放 | 中文字幕福利视频 | 久久久福利 | 欧美插插视频 | 国产白浆在线观看 | 禁断介护老人中文字幕 | 中文字幕在线免费视频 | 波多在线播放 |