ASP.NET操作Excel(终极方法NPOI)

开发 后端
ASP.NET操作Excel已经是老生长谈的事情了,可下面我说的这个NPOI操作Excel,应该是最好的方案了,没有之一,能够帮助开发者在没有安装微软Office的情况下读写Office 97-2003的文件,支持的文件格式包括xls, doc, ppt等。

前言

ASP.NET操作Excel已经是老生长谈的事情了,可下面我说的这个NPOI操作Excel,应该是***的方案了,没有之一,使用NPOI能够帮助开发者在没有安装微软Office的情况下读写Office 97-2003的文件,支持的文件格式包括xls, doc, ppt等。NPOI是构建在POI 3.x版本之上的,它可以在没有安装Office的情况下对Word/Excel文档进行读写操作。

方法

先去官网:http://npoi.codeplex.com/下载需要引入dll(可以选择.net2.0或者.net4.0的dll),然后在网站中添加引用。

导出代码:

  1. NPOI.HSSF.UserModel.HSSFWorkbook book = new NPOI.HSSF.UserModel.HSSFWorkbook();  
  2. NPOI.SS.UserModel.ISheet sheet = book.CreateSheet("test_01");  
  3.  
  4. // ***列  
  5. NPOI.SS.UserModel.IRow row = sheet.CreateRow(0);  
  6. row.CreateCell(0).SetCellValue("***列***行");  
  7.  
  8. // 第二列  
  9. NPOI.SS.UserModel.IRow row2 = sheet.CreateRow(1);  
  10. row2.CreateCell(0).SetCellValue("第二列***行");  
  11.  
  12. // ...  
  13.  
  14. // 写入到客户端    
  15. System.IO.MemoryStream ms = new System.IO.MemoryStream();  
  16. book.Write(ms);  
  17. Response.AddHeader("Content-Disposition"string.Format("attachment; filename={0}.xls", DateTime.Now.ToString("yyyyMMddHHmmssfff")));  
  18. Response.BinaryWrite(ms.ToArray());  
  19. book = null;  
  20. ms.Close();  
  21. ms.Dispose(); 

导入代码:

  1. HSSFWorkbook hssfworkbook;    
  2. #region    
  3. public DataTable ImportExcelFile(string filePath)    
  4. {    
  5.     #region//初始化信息    
  6.     try    
  7.     {    
  8.         using (FileStream file = new FileStream(filePath, FileMode.Open, FileAccess.Read))    
  9.         {    
  10.             hssfworkbook = new HSSFWorkbook(file);    
  11.         }    
  12.     }    
  13.     catch (Exception e)    
  14.     {    
  15.         throw e;    
  16.     }    
  17.     #endregion    
  18.     
  19.     NPOI.SS.UserModel.Sheet sheet = hssfworkbook.GetSheetAt(0);    
  20.     System.Collections.IEnumerator rows = sheet.GetRowEnumerator();    
  21.     DataTable dt = new DataTable();    
  22.     for (int j = 0; j < (sheet.GetRow(0).LastCellNum); j++)    
  23.     {    
  24.         dt.Columns.Add(Convert.ToChar(((int)'A') + j).ToString());    
  25.     }    
  26.     while (rows.MoveNext())    
  27.     {    
  28.         HSSFRow row = (HSSFRow)rows.Current;    
  29.         DataRow dr = dt.NewRow();    
  30.         for (int i = 0; i < row.LastCellNum; i++)    
  31.         {    
  32.             NPOI.SS.UserModel.Cell cell = row.GetCell(i);    
  33.             if (cell == null)    
  34.             {    
  35.                 dr[i] = null;    
  36.             }    
  37.             else    
  38.             {    
  39.                 dr[i] = cell.ToString();    
  40.             }    
  41.         }    
  42.         dt.Rows.Add(dr);    
  43.     }    
  44.     return dt;    
  45. }    
  46. #endregion 

结论

这样就很简单的解决Excel的操作了,大家可以试试,很好用,如果觉得对您有用请推荐一下,谢谢。

原文链接:http://www.cnblogs.com/stone_w/archive/2012/08/02/2620528.html

【编辑推荐】

  1. ASP.NET MVC涉及到的5个同步与异步
  2. YQBlog .NET MVC3博客系统之用户系统实战
  3. ASP.NET Cache的一些总结
  4. ASP.NET中常用的几种身份验证方式
  5. 各自为政:ASP.NET实现团队分工的思考
责任编辑:张伟 来源: 王磊的博客
相关推荐

2009-07-28 10:26:30

ASP.NET操作Ex

2021-02-02 07:47:36

NPOI基础Excel

2009-08-05 17:15:21

ASP.NET结束Ex

2009-07-28 11:23:04

Excel导入SQL

2009-08-05 16:59:38

ASP.NET调用Ex

2009-07-28 10:01:16

ASP.NET Exc

2009-08-05 14:19:12

ASP.NET输出EX

2009-07-28 13:26:34

Render方法ASP.NET

2009-07-28 11:00:24

Excel导入SQL

2009-07-22 17:45:35

ASP.NET教程

2011-11-22 09:32:39

ASP.NET

2009-07-30 13:28:55

ASP.NET中的ja

2021-02-04 07:22:07

NPOI操作Excel

2009-08-03 14:22:33

什么是ASP.NET

2009-07-28 17:17:19

ASP.NET概述

2009-07-28 10:36:37

ASP.NET读取Ex

2011-06-08 11:36:16

ASP.NETrender

2009-07-24 16:05:05

调用Web ServiASP.NET

2009-08-04 17:28:45

Apache支持ASP

2009-07-20 16:04:37

ASP.NET fra
点赞
收藏

51CTO技术栈公众号