這篇文章主要介紹了.NET操作Excel實例,有需要的朋友可以參考一下
1. 讀取 讀取好像有幾種方式,通過ADO.net, 通過Microsoft.Interop.Excel支持類庫用調用COM讀取,還有通過ZIP解壓最終讀取DOM(這個貌似蠻復雜) 這裡我用的ADO.NET只介紹這一個。 代碼如下: public DataTable ExcelToDataTable(string strExcelPath, string strSheetName) { string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + strExcelPath + ";" + "Extended Properties=Excel 5.0;"; string strExcel = string.Format("select * from [{0}$]", strSheetName); DataSet ds = new DataSet(); OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, strConn); adapter.Fill(ds, strSheetName); conn.Close(); return ds.Tables[strSheetName]; } 參數: StrExcelPath Excel文件的路徑,strSheetName 要讀取表的名稱 這裡貼個讀SheetName的代碼,這個是調用Microsoft.Interop.Excel來讀取 Excel.Workbook theWorkbook = ExcelObj.Workbooks.Open("Excel文件路徑", 0, true, 5, "", "", true, Excel.XlPlatform.xlWindows, "t", false, false, 0, true); Excel.Sheets sheets = theWorkbook.Worksheets; Excel.Worksheet worksheet = (Excel.Worksheet)sheets.get_Item(1); ExecName = worksheet.Name; theWorkbook.Close(null, null, null);//記得要關閉,否則程序關閉,Excel的進程還在 2.創建新的excel文件 代碼如下: Excel.ApplicationClass myExcel = new Excel.ApplicationClass(); //實例一個excel Excel._Workbook xBk; //工作薄 相當於一個Excel文件 Excel._Worksheet xSt; //工作Sheet 一個文件裡的表 xBk = myExcel.Workbooks.Add(true); //允許添加 sheet object missing = System.Reflection.Missing.Value;//空值 myExcel.Sheets.Add(missing, missing, 1, Excel.XlSheetType.xlWorksheet);//添加sheet xSt = (Excel._Worksheet)xBk.ActiveSheet;//得到默認sheet xSt.Name = "新的表"; //這裡設置表名 xBk.SaveAs( “保存路徑” , missing, missing, missing, missing, missing, Excel.XlSaveAsAccessMode.xlShared, missing, missing, missing, missing); //保存文件 myExcel.Quit(); //同樣要記得關閉 3.添加內容 這裡只說一般數據的添加,圖表的就不介紹了, 在Excel的操作裡一般是以表格和范圍為單位,行或列是從1開始而不是從0開始 先介紹一下格式設置,如下 如設置第一行字體為紅色:((Excel.Range)xSt.Rows[1, Type.Missing]).Font.Color = 0xFF0000; //xSt 是上邊代碼的變量名,顏色值是用16進制RGB 設置第二列為百分數的格式 ((Excel.Range)xSt.Columns[2, Type.Missing]).NumberFormat = "0.00%"; 備常用格式:文本:@ 日期:yyyy/mm/dd 數字:#,##0.00 貨幣:¥#,##0.00 百分比:0.00% 上邊兩種為行選擇和列選擇,如果要選擇第1行第2列到第1行第5列就用get_Range(); xSt.get_Range(xSt.Cells[1,2],xSt.Cells[1,5]) 如果需要其它格式,如單元格背景,邊框,字體樣式 ,查下文檔。不過大部分從點出來的方法名就能知道了 再就是添加內容,直接寫點代碼參考。 代碼如下: int rowIdx = 2; //從第2行列始 //這裡dt 是DataTable數據源 foreach( DataRow dr in dt.Rows ) { int j = 1; //從第1列開始 myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); //用公式的情況,顯示A+B+C+D的結果 myExcel.Cells[rowIdx, j++] = string.Format("=SUM(A{0}:D{0})",rowIdx); rowIdx++; } 寫完了save一下 xBk.Save(),還是記得要關閉。