佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > .NET操作Excel實例分享

.NET操作Excel實例分享

熱門標簽:百度AI接口 電銷業(yè)務 網(wǎng)站排名優(yōu)化 科大訊飛語音識別系統(tǒng) 客戶服務 國美全國運營中心 人工智能 電商新玩法

1. 讀取

讀取好像有幾種方式,通過ADO.net, 通過Microsoft.Interop.Excel支持類庫用調(diào)用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];
}

參數(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);//記得要關閉,否則程序關閉,Excel的進程還在
2.創(chuàng)建新的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.添加內(nèi)容
這里只說一般數(shù)據(jù)的添加,圖表的就不介紹了, 在Excel的操作里一般是以表格和范圍為單位,行或列是從1開始而不是從0開始
先介紹一下格式設置,如下
如設置第一行字體為紅色:((Excel.Range)xSt.Rows[1, Type.Missing]).Font.Color = 0xFF0000;      //xSt 是上邊代碼的變量名,顏色值是用16進制RGB
設置第二列為百分數(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)容,直接寫點代碼參考。

復制代碼 代碼如下:

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(),還是記得要關閉。

您可能感興趣的文章:
  • Asp.Net 無刷新文件上傳并顯示進度條的實現(xiàn)方法及思路
  • VB.NET進度條的方法代碼
  • asp.net(c#)開發(fā)中的文件上傳組件uploadify的使用方法(帶進度條)
  • asp.net 在客戶端顯示服務器端任務處理進度條的探討
  • asp.net 生成靜態(tài)頁時的進度條顯示
  • 利用Asp.Net回調(diào)機制實現(xiàn)進度條
  • asp.net web大文件上傳帶進度條實例代碼
  • ASP.NET實現(xiàn)用圖片進度條顯示投票結(jié)果
  • ASP.NET技巧:教你制做Web實時進度條
  • asp.net導出excel數(shù)據(jù)的常見方法匯總
  • ASP.NET中上傳并讀取Excel文件數(shù)據(jù)示例
  • asp.net讀取excel文件的三種方法示例
  • 進度條在.net導入Excel時的應用實例

標簽:POS機 棗莊 咸寧 南平 攀枝花 廈門 拉薩 益陽

巨人網(wǎng)絡通訊聲明:本文標題《.NET操作Excel實例分享》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    铜川市| 正定县| 陕西省| 陈巴尔虎旗| 洛宁县| 汝阳县| 辽源市| 阿坝县| 静乐县| 苍梧县| 南昌县| 黔西县| 上虞市| 怀远县| 措美县| 房山区| 永安市| 樟树市| 天门市| 合作市| 思茅市| 疏勒县| 莱芜市| 廉江市| 巩义市| 抚州市| 张家口市| 潞城市| 青铜峡市| 招远市| 蒲城县| 固镇县| 邯郸县| 罗山县| 土默特右旗| 瓦房店市| 伊宁市| 清流县| 虞城县| 靖西县| 宁夏|