C#通過NPOI操作Excel的實例代碼
C#操作Excel的方法有很多種,常見的有微軟官方的OLE Automation,Apache的POI等。這里介紹的是POI翻譯成C#的NPOI。
POI是Apache的通過Java操作Office的一個API,可以對Excel,Word,PPT等進行操作,十分的強大。然后就被翻譯成C#版本的NPOI了,和log4j與log4net很相似。
好像在NPOI的.net4.0版本之前是不支持office2007及以上的XML格式的,但是最新的版本已經(jīng)支持了。只需要下載并引用下面五個程序集就能使用了。

這里提供一個操作Excel的類,類中提供了4個方法,兩個導出,兩個導入。可以通過DataSet導出擁有多個Sheet的Excel文件,也可以通過DataTable導出擁有一個Sheet的Excel。導入也是一樣,通過指定Sheet索引,導出DataTable,或者直接導出所有Sheet返回一個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索引,可選,默認返回所有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導出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導出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)容返回為對應(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)很好的實現(xiàn)了兼容,但是如果是2007版本的xlsm被修改為xsl的后綴怎么辦呢,或者2003版本的被修改為xlsm后綴怎么辦呢。2003版本改為xlsm還是可以將其視為xls來處理的,但是2007改為xls就不行了。這時候可以強行修改文件的后綴名再打開。
但是上面的代碼沒有實現(xiàn)這個功能,兩個原因:一、這樣做不是很安全。二、這時候需要修改系統(tǒng)中其它地方此文件的文件名,放在類中實現(xiàn)不是很方便。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- C#實現(xiàn)DataSet內(nèi)數(shù)據(jù)轉(zhuǎn)化為Excel和Word文件的通用類完整實例
- C#將Excel中的數(shù)據(jù)轉(zhuǎn)換成DataSet
- C#使用NPOI導入Excel的方法詳解
- C#基于NPOI生成具有精確列寬行高的Excel文件的方法
- c# 根據(jù)NPOI 讀取一個excel 文件的多個Sheet
- c# 應(yīng)用NPOI獲取Excel中的圖片,保存至本地的算法
- C#使用NPOI上傳excel
- C# 基于NPOI操作Excel
- C#實現(xiàn)NPOI的Excel導出詳解
- C#使用NPOI讀取excel轉(zhuǎn)為DataSet
相關(guān)文章
使用C#獲取遠程圖片 Form用戶名與密碼Authorization認證的實現(xiàn)
本篇文章介紹了,使用C#獲取遠程圖片 Form用戶名與密碼Authorization認證的實現(xiàn)。需要的朋友參考下2013-04-04

