一、將DataTable內容寫入到CSV檔案
/// <summary>
/// 將DataTable中的資料儲存成CSV檔案
/// </summary>
private void btnSaveCSV_Click(object sender, EventArgs e)
{
saveFileDialog1.Filter = "CSV檔案|*.CSV";
saveFileDialog1.InitialDirectory = "C:\\";
if (saveFileDialog1.ShowDialog() == DialogResult.Cancel)
{
return;
}
else
{
string fileName = saveFileDialog1.FileName;
SaveCSV(ds.Tables[0], fileName);
}
}
/// <summary>
/// 將DataTable中資料寫入到CSV檔案中
/// </summary>
/// <param name="dt">提供儲存資料的DataTable</param>
/// <param name="fileName">CSV的檔案路徑</param>
public void SaveCSV(DataTable dt, string fileName)
{
FileStream fs = new FileStream(fileName, System.IO.FileMode.Create, System.IO.FileAccess.Write);
StreamWriter sw = new StreamWriter(fs, System.Text.Encoding.Default);
string data = "";
//寫出列名稱
for (int i = 0; i < dt.Columns.Count; i++)
{
data += dt.Columns[i].ColumnName.ToString();
if (i < dt.Columns.Count - 1)
{
data += ",";
}
}
sw.WriteLine(data);
//寫出各行資料
for (int i = 0; i < dt.Rows.Count; i++)
{
data = "";
for (int j = 0; j < dt.Columns.Count; j++)
{
data += dt.Rows[i][j].ToString();
if (j < dt.Columns.Count - 1)
{
data += ",";
}
}
sw.WriteLine(data);
}
sw.Close();
fs.Close();
MessageBox.Show("CSV檔案儲存成功!");
}
二、將CSV檔案內容讀取到DataTable中
/// <summary>
/// 開啟CSV並顯示其資料
/// </summary>
private void btnOpenCSV_Click(object sender, EventArgs e)
{
openFileDialog1.Filter = "CSV檔案|*.CSV";
if (openFileDialog1.ShowDialog() == DialogResult.Cancel)
{
return;
}
else
{
this.dgvShow.DataSource = null;
string fileName = openFileDialog1.FileName;
this.dgvShow.DataSource = OpenCSV(fileName);
MessageBox.Show("成功顯示CSV資料!");
}
}
/// <summary>
/// 將CSV檔案的資料讀取到DataTable中
/// </summary>
/// <param name="fileName">CSV檔案路徑</param>
/// <returns>返回讀取了CSV資料的DataTable</returns>
public DataTable OpenCSV(string fileName)
{
DataTable dt = new DataTable();
FileStream fs = new FileStream(fileName, System.IO.FileMode.Open, System.IO.FileAccess.Read);
StreamReader sr = new StreamReader(fs, System.Text.Encoding.Default);
//記錄每次讀取的一行記錄
string strLine = "";
//記錄每行記錄中的各欄位內容
string[] aryLine;
//標示列數
int columnCount = 0;
//標示是否是讀取的第一行
bool IsFirst = true;
//逐行讀取CSV中的資料
while ((strLine = sr.ReadLine()) != null)
{
aryLine=strLine.Split(',');
if (IsFirst == true)
{
IsFirst = false;
columnCount = aryLine.Length;
//建立列
for (int i = 0; i < columnCount; i++)
{
DataColumn dc = new DataColumn(aryLine[i]);
dt.Columns.Add(dc);
}
}
else
{
DataRow dr = dt.NewRow();
for (int j = 0; j < columnCount; j++)
{
dr[j] = aryLine[j];
}
dt.Rows.Add(dr);
}
}
sr.Close();
fs.Close();
return dt;
}