C#數(shù)據(jù)導入到EXCEL的方法
c#做公司的應用級開發(fā)時,導出數(shù)據(jù)這個是經(jīng)常要做的,公司使用的是一個叫NPOI的組件。具體是什么我就不很清楚,反正這樣用就是了。
具體的dll是一個叫:NPOI.HSSF.dll,引入這個dll,這個dll提供HSSFWorkbook類 HSSFSheet類HSSFRow類;
具體實現(xiàn)方式直接看代碼吧:
public static Stream DataSetToExcel(DataSet _SourceDt,string _sheetName) { HSSFWorkbook workbook = new HSSFWorkbook(); MemoryStream MS = new MemoryStream(); string [] sheetNames= _sheetName.Split(','); for(int i = 0; i <sheetNames.Length;i++) { HSSFSheet sheet = workbook.Cretesheet(sheetNames[i]); HSSFRow headRow = sheet.CreateRow(0); foreach(DataColumn column in _SourceDt.Table[i].cloumns) headRow.createCell(column.Ordinal).SetCellValue(column.Column.Name); int rowIndex =1; foreach(DataRow row in _SourceDt.Tables[i].Rows) { HSSFRow dataRow = sheet.CreateRow(rowIndex); foreach(DataColumn column in _SourceDt.Tables[i].Columns) { dataRow.CreateCell(column.Ordinal).SetCellValue(row[column].ToString()); } rowIndex++; } } workbook.write(MS); MS.Flush(); MS.Position = 0; workbook = null; return MS; }
主要是要構(gòu)建一個數(shù)據(jù)來源的DataSet ;還是直接上代碼吧:
DataTable dt = new DataTable(); DataSet DataTemp = new DataSet(); dt.Columns.Add("列名1",string); dt.Columns.Add("列名2",string ); for(int i = 0;i<3;i++) { DataRow DR = dt.NewRow(); DR["列名1"] = "DATA1"; DR["列名2"] = "DATA1"; dt.Rows.Add(DR); } DataTemp.Tables.Add(dt);
DATA1和DATA2就是你要導出的數(shù)據(jù)了。
以上不是開發(fā)的源代碼,只是方法。僅供參考;
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
C#實現(xiàn)動態(tài)執(zhí)行字符串腳本(優(yōu)化版)的示例代碼
這篇文章主要為大家詳細介紹了C#如何實現(xiàn)動態(tài)執(zhí)行字符串腳本(優(yōu)化版),文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2023-03-03給c#添加SetTimeout和SetInterval函數(shù)
Javascript中的SetTimeout和SetInterval函數(shù)很方便,把他們移植到c#中來。2008-03-03C#實現(xiàn)數(shù)據(jù)包加密與解密實例詳解
這篇文章主要介紹了C#實現(xiàn)數(shù)據(jù)包加密與解密的方法,是一項很實用的技能,需要的朋友可以參考下2014-07-07DataGridView清除顯示的數(shù)據(jù)、設(shè)定右鍵菜單
這篇文章介紹了DataGridView清除顯示的數(shù)據(jù)、設(shè)定右鍵菜單的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-02-02