C#通過NPOI操作Excel的實(shí)例代碼
C#操作Excel的方法有很多種,常見的有微軟官方的OLE Automation,Apache的POI等。這里介紹的是POI翻譯成C#的NPOI。
POI是Apache的通過Java操作Office的一個(gè)API,可以對(duì)Excel,Word,PPT等進(jìn)行操作,十分的強(qiáng)大。然后就被翻譯成C#版本的NPOI了,和log4j與log4net很相似。
好像在NPOI的.net4.0版本之前是不支持office2007及以上的XML格式的,但是最新的版本已經(jīng)支持了。只需要下載并引用下面五個(gè)程序集就能使用了。
這里提供一個(gè)操作Excel的類,類中提供了4個(gè)方法,兩個(gè)導(dǎo)出,兩個(gè)導(dǎo)入。可以通過DataSet導(dǎo)出擁有多個(gè)Sheet的Excel文件,也可以通過DataTable導(dǎo)出擁有一個(gè)Sheet的Excel。導(dǎo)入也是一樣,通過指定Sheet索引,導(dǎo)出DataTable,或者直接導(dǎo)出所有Sheet返回一個(gè)DataSet。
public class ExcelHelper { /// <summary> /// 根據(jù)Excel和Sheet返回DataTable /// </summary> /// <param name="filePath">Excel文件地址</param> /// <param name="sheetIndex">Sheet索引</param> /// <returns>DataTable</returns> public static DataTable GetDataTable(string filePath, int sheetIndex) { return GetDataSet(filePath, sheetIndex).Tables[0]; } /// <summary> /// 根據(jù)Excel返回DataSet /// </summary> /// <param name="filePath">Excel文件地址</param> /// <param name="sheetIndex">Sheet索引,可選,默認(rèn)返回所有Sheet</param> /// <returns>DataSet</returns> public static DataSet GetDataSet(string filePath, int? sheetIndex = null) { DataSet ds = new DataSet(); IWorkbook fileWorkbook; using (FileStream fs = new FileStream(filePath, FileMode.Open, FileAccess.Read)) { if (filePath.Last() == 's') { try { fileWorkbook = new HSSFWorkbook(fs); } catch (Exception ex) { throw ex; } } else { try { fileWorkbook = new XSSFWorkbook(fs); } catch { fileWorkbook = new HSSFWorkbook(fs); } } } for (int i = 0; i < fileWorkbook.NumberOfSheets; i++) { if (sheetIndex != null && sheetIndex != i) continue; DataTable dt = new DataTable(); ISheet sheet = fileWorkbook.GetSheetAt(i); //表頭 IRow header = sheet.GetRow(sheet.FirstRowNum); List<int> columns = new List<int>(); for (int j = 0; j < header.LastCellNum; j++) { object obj = GetValueTypeForXLS(header.GetCell(j) as HSSFCell); if (obj == null || obj.ToString() == string.Empty) { dt.Columns.Add(new DataColumn("Columns" + j.ToString())); } else dt.Columns.Add(new DataColumn(obj.ToString())); columns.Add(j); } //數(shù)據(jù) IEnumerator rows = sheet.GetEnumerator(); while (rows.MoveNext()) { int j = sheet.FirstRowNum + 1; DataRow dr = dt.NewRow(); bool hasValue = false; foreach (int K in columns) { dr[K] = GetValueTypeForXLS(sheet.GetRow(K).GetCell(K) as HSSFCell); if (dr[K] != null && dr[K].ToString() != string.Empty) { hasValue = true; } } if (hasValue) { dt.Rows.Add(dr); } j++; } ds.Tables.Add(dt); } return ds; } /// <summary> /// 根據(jù)DataTable導(dǎo)出Excel /// </summary> /// <param name="dt">DataTable</param> /// <param name="file">保存地址</param> public static void GetExcelByDataTable(DataTable dt, string file) { DataSet ds = new DataSet(); ds.Tables.Add(dt); GetExcelByDataSet(ds, file); } /// <summary> /// 根據(jù)DataSet導(dǎo)出Excel /// </summary> /// <param name="ds">DataSet</param> /// <param name="file">保存地址</param> public static void GetExcelByDataSet(DataSet ds, string file) { IWorkbook fileWorkbook = new HSSFWorkbook(); int index = 0; foreach (DataTable dt in ds.Tables) { index++; ISheet sheet = fileWorkbook.CreateSheet("Sheet" + index); //表頭 IRow row = sheet.CreateRow(0); for (int i = 0; i < dt.Columns.Count; i++) { ICell cell = row.CreateCell(i); cell.SetCellValue(dt.Columns[i].ColumnName); } //數(shù)據(jù) for (int i = 0; i < dt.Rows.Count; i++) { IRow row1 = sheet.CreateRow(i + 1); for (int j = 0; j < dt.Columns.Count; j++) { ICell cell = row1.CreateCell(j); cell.SetCellValue(dt.Rows[i][j].ToString()); } } } //轉(zhuǎn)為字節(jié)數(shù)組 MemoryStream stream = new MemoryStream(); fileWorkbook.Write(stream); var buf = stream.ToArray(); //保存為Excel文件 using (FileStream fs = new FileStream(file, FileMode.Create, FileAccess.Write)) { fs.Write(buf, 0, buf.Length); fs.Flush(); } } /// <summary> /// 根據(jù)單元格將內(nèi)容返回為對(duì)應(yīng)類型的數(shù)據(jù) /// </summary> /// <param name="cell">單元格</param> /// <returns>數(shù)據(jù)</returns> private static object GetValueTypeForXLS(HSSFCell cell) { if (cell == null) return null; switch (cell.CellType) { case CellType.Blank: //BLANK: return null; case CellType.Boolean: //BOOLEAN: return cell.BooleanCellValue; case CellType.Numeric: //NUMERIC: return cell.NumericCellValue; case CellType.String: //STRING: return cell.StringCellValue; case CellType.Error: //ERROR: return cell.ErrorCellValue; case CellType.Formula: //FORMULA: default: return "=" + cell.CellFormula; } } }
這里面可以有一些有意思的操作,比如版本兼容問題。這里通過多態(tài)很好的實(shí)現(xiàn)了兼容,但是如果是2007版本的xlsm被修改為xsl的后綴怎么辦呢,或者2003版本的被修改為xlsm后綴怎么辦呢。2003版本改為xlsm還是可以將其視為xls來處理的,但是2007改為xls就不行了。這時(shí)候可以強(qiáng)行修改文件的后綴名再打開。
但是上面的代碼沒有實(shí)現(xiàn)這個(gè)功能,兩個(gè)原因:一、這樣做不是很安全。二、這時(shí)候需要修改系統(tǒng)中其它地方此文件的文件名,放在類中實(shí)現(xiàn)不是很方便。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C#實(shí)現(xiàn)DataSet內(nèi)數(shù)據(jù)轉(zhuǎn)化為Excel和Word文件的通用類完整實(shí)例
- C#將Excel中的數(shù)據(jù)轉(zhuǎn)換成DataSet
- C#使用NPOI導(dǎo)入Excel的方法詳解
- C#基于NPOI生成具有精確列寬行高的Excel文件的方法
- c# 根據(jù)NPOI 讀取一個(gè)excel 文件的多個(gè)Sheet
- c# 應(yīng)用NPOI獲取Excel中的圖片,保存至本地的算法
- C#使用NPOI上傳excel
- C# 基于NPOI操作Excel
- C#實(shí)現(xiàn)NPOI的Excel導(dǎo)出詳解
- C#使用NPOI讀取excel轉(zhuǎn)為DataSet
相關(guān)文章
直接在線預(yù)覽Word、Excel、TXT文件之ASP.NET
這篇文章主要用asp.net技術(shù)實(shí)現(xiàn)直接在線預(yù)覽word、excel、txt文件,有需要的朋友可以參考下2015-08-08C#中DataGridView常用操作實(shí)例小結(jié)
這篇文章主要介紹了C#中DataGridView常用操作,以實(shí)例形式總結(jié)了DataGridView綁定下拉列表、設(shè)置默認(rèn)值、判斷復(fù)選框是否選中等技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09C#開發(fā)微信門戶及應(yīng)用(5) 用戶分組信息管理
這篇文章主要為大家詳細(xì)介紹了C#開發(fā)微信門戶及應(yīng)用第五篇,用戶分組信息管理,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06C#事務(wù)處理(Execute Transaction)實(shí)例解析
這篇文章主要介紹了C#事務(wù)處理(Execute Transaction)實(shí)例解析,對(duì)于理解和學(xué)習(xí)事務(wù)處理有一定的幫助,需要的朋友可以參考下2014-08-08C#創(chuàng)建安全的字典(Dictionary)存儲(chǔ)結(jié)構(gòu)
本文主要對(duì)存儲(chǔ)結(jié)構(gòu)字典(Dictionary)的一些常用方法進(jìn)行簡單的說明,并闡述了如何創(chuàng)建安全的字典(Dictionary)存儲(chǔ)結(jié)構(gòu)。希望對(duì)大家有所幫助2016-12-12