您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“怎么用.NET操作Excel”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“怎么用.NET操作Excel”吧!
1. 讀取
讀取好像有幾種方式,通過ADO.net, 通過Microsoft.Interop.Excel支持類庫用調(diào)用COM讀取,還有通過ZIP解壓最終讀取DOM(這個貌似蠻復(fù)雜)
這里我用的ADO.NET只介紹這一個。
復(fù)制代碼 代碼如下:
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];
}
參數(shù): StrExcelPath Excel文件的路徑,strSheetName 要讀取表的名稱
這里貼個讀SheetName的代碼,這個是調(diào)用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);//記得要關(guān)閉,否則程序關(guān)閉,Excel的進程還在
2.創(chuàng)建新的excel文件
復(fù)制代碼 代碼如下:
Excel.ApplicationClass myExcel = new Excel.ApplicationClass(); //實例一個excel
Excel._Workbook xBk; //工作薄 相當(dāng)于一個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 = "新的表"; //這里設(shè)置表名
xBk.SaveAs( “保存路徑” , missing, missing,
missing, missing, missing, Excel.XlSaveAsAccessMode.xlShared,
missing, missing, missing, missing); //保存文件
myExcel.Quit(); //同樣要記得關(guān)閉
3.添加內(nèi)容
這里只說一般數(shù)據(jù)的添加,圖表的就不介紹了, 在Excel的操作里一般是以表格和范圍為單位,行或列是從1開始而不是從0開始
先介紹一下格式設(shè)置,如下
如設(shè)置第一行字體為紅色:((Excel.Range)xSt.Rows[1, Type.Missing]).Font.Color = 0xFF0000; //xSt 是上邊代碼的變量名,顏色值是用16進制RGB
設(shè)置第二列為百分數(shù)的格式 ((Excel.Range)xSt.Columns[2, Type.Missing]).NumberFormat = "0.00%";
備常用格式:文本:@ 日期:yyyy/mm/dd 數(shù)字:#,##0.00 貨幣:¥#,##0.00 百分比:0.00%
上邊兩種為行選擇和列選擇,如果要選擇第1行第2列到第1行第5列就用get_Range();
xSt.get_Range(xSt.Cells[1,2],xSt.Cells[1,5])
如果需要其它格式,如單元格背景,邊框,字體樣式 ,查下文檔。不過大部分從點出來的方法名就能知道了
再就是添加內(nèi)容,直接寫點代碼參考。
復(fù)制代碼 代碼如下:
int rowIdx = 2; //從第2行列始
//這里dt 是DataTable數(shù)據(jù)源
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的結(jié)果
myExcel.Cells[rowIdx, j++] = string.Format("=SUM(A{0}:D{0})",rowIdx);
rowIdx++;
}
寫完了save一下 xBk.Save(),還是記得要關(guān)閉。
到此,相信大家對“怎么用.NET操作Excel”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。