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格式的,但是最新的版本已经支持了。只需要下载并引用下面五个程序集就能使用了。
这里提供一个操作Excel的类,类中提供了4个方法,两个导出,两个导入。可以通过DataSet导出拥有多个Sheet的Excel文件,也可以通过DataTable导出拥有一个Sheet的Excel。导入也是一样,通过指定Sheet索引,导出DataTable,或者直接导出所有Sheet返回一个DataSet。
public class ExcelHelper
{
/// <summary>
/// 根据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>
/// 根据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);
}
//数据
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>
/// 根据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>
/// 根据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);
}
//数据
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());
}
}
}
//转为字节数组
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>
/// 根据单元格将内容返回为对应类型的数据
/// </summary>
/// <param name="cell">单元格</param>
/// <returns>数据</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;
}
}
}
这里面可以有一些有意思的操作,比如版本兼容问题。这里通过多态很好的实现了兼容,但是如果是2007版本的xlsm被修改为xsl的后缀怎么办呢,或者2003版本的被修改为xlsm后缀怎么办呢。2003版本改为xlsm还是可以将其视为xls来处理的,但是2007改为xls就不行了。这时候可以强行修改文件的后缀名再打开。
但是上面的代码没有实现这个功能,两个原因:一、这样做不是很安全。二、这时候需要修改系统中其它地方此文件的文件名,放在类中实现不是很方便。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# npoi操作excel
# c#
# excel
# npoi
# C#实现DataSet内数据转化为Excel和Word文件的通用类完整实例
# C#将Excel中的数据转换成DataSet
# C#使用NPOI导入Excel的方法详解
# C#基于NPOI生成具有精确列宽行高的Excel文件的方法
# c# 根据NPOI 读取一个excel 文件的多个Sheet
# c# 应用NPOI获取Excel中的图片
# 保存至本地的算法
# C#使用NPOI上传excel
# C# 基于NPOI操作Excel
# C#实现NPOI的Excel导出详解
# C#使用NPOI读取excel转为DataSet
# 可以通过
# 翻译成
# 单元格
# 类中
# 的是
# 这时候
# 很好
# 放在
# 就能
# 多个
# 不是很
# 将其
# 微软
# 这样做
# 不支持
# 只需要
# 可选
# 提供一个
# 不行了
# 这里面
相关文章:
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
制作证书网站有哪些,全国城建培训中心证书查询官网?
中山网站推广排名,中山信息港登录入口?
如何获取PHP WAP自助建站系统源码?
b2c电商网站制作流程,b2c水平综合的电商平台?
如何实现建站之星域名转发设置?
建站之星导航配置指南:自助建站与SEO优化全解析
昆明网站制作哪家好,昆明公租房申请网上登录入口?
如何在阿里云购买域名并搭建网站?
建站之星安装模板失败:服务器环境不兼容?
宝塔Windows建站如何避免显示默认IIS页面?
浅析上传头像示例及其注意事项
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
如何确保西部建站助手FTP传输的安全性?
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
如何获取开源自助建站系统免费下载链接?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
如何通过西部数码建站助手快速创建专业网站?
网站制作企业,网站的banner和导航栏是指什么?
义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?
济南专业网站制作公司,济南信息工程学校怎么样?
高防网站服务器:DDoS防御与BGP线路的AI智能防护方案
如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
购物网站制作公司有哪些,哪个购物网站比较好?
如何在云主机上快速搭建网站?
建站主机选哪种环境更利于SEO优化?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
如何通过VPS建站实现广告与增值服务盈利?
建站VPS能否同时实现高效与安全翻墙?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
,有什么在线背英语单词效率比较高的网站?
教学网站制作软件,学习*后期制作的网站有哪些?
公司网站的制作公司,企业网站制作基本流程有哪些?
微信h5制作网站有哪些,免费微信H5页面制作工具?
已有域名如何快速搭建专属网站?
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
实现虚拟支付需哪些建站技术支撑?
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
如何高效完成自助建站业务培训?
武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
如何自定义建站之星模板颜色并下载新样式?
网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?
动图在线制作网站有哪些,滑动动图图集怎么做?
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
如何通过虚拟机搭建网站?详细步骤解析
*请认真填写需求信息,我们会在24小时内与您取得联系。