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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > C# >内容正文

C#

C#读取Excel表格数据到DataGridView中和导出DataGridView中的数据到Excel

發(fā)布時間:2023/12/20 C# 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C#读取Excel表格数据到DataGridView中和导出DataGridView中的数据到Excel 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
  • 其實想在datagridview中顯示excel表格中的數(shù)據(jù)跟讀取數(shù)據(jù)庫中的數(shù)據(jù)沒什么差別,只不過是創(chuàng)建數(shù)據(jù)庫連接的時候連接字段稍有差別。
  • private void btnShow_Click(object sender, EventArgs e){OpenFileDialog fd = new OpenFileDialog();//首先根據(jù)打開文件對話框,選擇excel表格ofd.Filter = "表格|*.xls";//打開文件對話框篩選器string strPath;//文件完整的路徑名if (ofd.ShowDialog() == DialogResult.OK){try{strPath = ofd.FileName;string strCon = "provider=microsoft.jet.oledb.4.0;data source=" + strPath + ";extended properties=excel 8.0";//關(guān)鍵是紅色區(qū)域OleDbConnection Con = new OleDbConnection(strCon);//建立連接string strSql = "select * from [Sheet1$]";//表名的寫法也應(yīng)注意不同,對應(yīng)的excel表為sheet1,在這里要在其后加美元符號$,并用中括號OleDbCommand Cmd = new OleDbCommand(strSql, Con);//建立要執(zhí)行的命令OleDbDataAdapter da = new OleDbDataAdapter(Cmd);//建立數(shù)據(jù)適配器DataSet ds = new DataSet();//新建數(shù)據(jù)集da.Fill(ds, "shyman");//把數(shù)據(jù)適配器中的數(shù)據(jù)讀到數(shù)據(jù)集中的一個表中(此處表名為shyman,可以任取表名)//指定datagridview1的數(shù)據(jù)源為數(shù)據(jù)集ds的第一張表(也就是shyman表),也可以寫ds.Table["shyman"] dataGridView1.DataSource = ds.Tables[0];}catch (Exception ex){MessageBox.Show(ex.Message);//捕捉異常 }}}

    運行結(jié)果如下:

    2.導(dǎo)出DataGridView中的數(shù)據(jù)到Excel的方法:

    public void ToExcel(DataGridView dataGridView1){try{//沒有數(shù)據(jù)的話就不往下執(zhí)行 if (dataGridView1.Rows.Count == 0)return;//實例化一個Excel.Application對象 Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();//讓后臺執(zhí)行設(shè)置為不可見,為true的話會看到打開一個Excel,然后數(shù)據(jù)在往里寫 excel.Visible = true;//新增加一個工作簿,Workbook是直接保存,不會彈出保存對話框,加上Application會彈出保存對話框,值為false會報錯 excel.Application.Workbooks.Add(true);//生成Excel中列頭名稱 for (int i = 0; i < dataGridView1.Columns.Count; i++){if (this.dataGridView1.Columns[i].Visible==true){excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;}}//把DataGridView當(dāng)前頁的數(shù)據(jù)保存在Excel中 for (int i = 0; i < dataGridView1.Rows.Count - 1; i++){System.Windows.Forms.Application.DoEvents();for (int j = 0; j < dataGridView1.Columns.Count; j++){if (this.dataGridView1.Columns[j].Visible==true){if (dataGridView1[j, i].ValueType == typeof(string)){excel.Cells[i + 2, j + 1] = "'" + dataGridView1[j, i].Value.ToString();}else{excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString();}}}}//設(shè)置禁止彈出保存和覆蓋的詢問提示框 excel.DisplayAlerts = false;excel.AlertBeforeOverwriting = false;//保存工作簿 excel.Application.Workbooks.Add(true).Save();//保存excel文件 excel.Save("D:" + "\\KKHMD.xls");//確保Excel進程關(guān)閉 excel.Quit();excel = null;GC.Collect();//如果不使用這條語句會導(dǎo)致excel進程無法正常退出,使用后正常退出MessageBox.Show(this,"文件已經(jīng)成功導(dǎo)出!","信息提示");}catch (Exception ex){MessageBox.Show(ex.Message, "錯誤提示");}}

    ?

    轉(zhuǎn)載于:https://www.cnblogs.com/kongxiaoshuang/p/6062368.html

    總結(jié)

    以上是生活随笔為你收集整理的C#读取Excel表格数据到DataGridView中和导出DataGridView中的数据到Excel的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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