C#使用NPOI上傳excel
寫本文章的目的是為了記錄工作中遇到的問題,方便以后遇到可以迅速解決問題
我使用的NPOI版本是2.2.1.0版本
需要用到的命名空間
using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel;
首先需要讀取excel文件中的內(nèi)容轉(zhuǎn)為表格
string path為excel表格文件的在本地的地址
Stream fs為上傳文件的流可以根據(jù)Request.Files[0].InputStream 獲得
public DataTable GetexcelDataSet(string path, Stream fs) { IWorkbook workbook = null; if (path.IndexOf(".xlsx") > 0) { workbook = new XSSFWorkbook(fs);//excel的版本2007 } else if (path.IndexOf(".xls") > 0) { workbook = new HSSFWorkbook(fs);//excel的版本2003 } ISheet sheet = workbook.GetSheetAt(0);//得到第一張表 DataTable table = new DataTable(); IRow headerRow = sheet.GetRow(0);//第一行為標題行 int cellCount = headerRow.LastCellNum;//LastCellNum = PhysicalNumberOfCells int rowCount = sheet.LastRowNum;//LastRowNum = PhysicalNumberOfRows - 1 for (int i = headerRow.FirstCellNum; i < cellCount; i++) { DataColumn column = new DataColumn(headerRow.GetCell(i).StringCellValue); table.Columns.Add(column);//添加行標題 } for (int i = (sheet.FirstRowNum + 1); i <= rowCount; i++) { IRow row = sheet.GetRow(i); DataRow dataRow = table.NewRow(); if (row != null) { for (int j = row.FirstCellNum; j < cellCount; j++) { if (row.GetCell(j) != null) dataRow[j] = row.GetCell(j); } } table.Rows.Add(dataRow); } return table; }
得到dateTable之后就是使用事物循環(huán)插入數(shù)據(jù)庫中,這個就不解釋了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:C#中反射和擴展方法如何運用
欄 目:C#教程
下一篇:使用C#編寫15子游戲
本文標題:C#使用NPOI上傳excel
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5741.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實現(xiàn)手動對資源的釋放
- 01-10C#3.0使用EventLog類寫Windows事件日志的方法
- 01-10C#使用windows服務(wù)開啟應(yīng)用程序的方法
- 01-10c# ArrayList的使用方法小總結(jié)
- 01-10C#使用ADO.Net部件來訪問Access數(shù)據(jù)庫的方法
- 01-10C#使用Mutex簡單實現(xiàn)程序單實例運行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10http圖片上傳安全性問題 根據(jù)ContentType (MIME) 判斷其實不準確、不
- 01-10C#遍歷文件夾后上傳文件夾中所有文件錯誤案例分析
- 01-10C#中yield用法使用說明


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻播放器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機閱讀
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10delphi制作wav文件的方法
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10C#中split用法實例總結(jié)
- 01-11ajax實現(xiàn)頁面的局部加載