官网:http://npoi.codeplex.com/

简单应用,主要是可以实现我们想要的简单效果,呵呵

需要引入dll,可以在官网下载,也可在下面下载

  1. protected void getExcel(DataTable dt)
  2. {
  3. NPOI.HSSF.UserModel.HSSFWorkbook book = new NPOI.HSSF.UserModel.HSSFWorkbook();
  4. NPOI.SS.UserModel.Sheet sheet = book.CreateSheet("test_01");
  5. NPOI.SS.UserModel.Row row = sheet.CreateRow(0);
  6. for (int i = 0; i < dt.Columns.Count; i++)
  7. {
  8. row.CreateCell(i).SetCellValue(dt.Columns[i].ColumnName);
  9. }
  10. for (int i = 0; i < dt.Rows.Count; i++)
  11. {
  12. NPOI.SS.UserModel.Row row2 = sheet.CreateRow(i + 1);
  13. for (int j = 0; j < dt.Columns.Count; j++)
  14. row2.CreateCell(j).SetCellValue(dt.Rows[i][j].ToString());
  15. }
  16. //写入到客户端
  17. System.IO.MemoryStream ms = new System.IO.MemoryStream();
  18. book.Write(ms);
  19. Response.AddHeader("Content-Disposition", string.Format("attachment; filename=EmptyWorkbook.xls"));
  20. Response.BinaryWrite(ms.ToArray());
  21. book = null;
  22. ms.Close();
  23. ms.Dispose();
  24. }

EXCEL导入

  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. NPOI.SS.UserModel.Sheet sheet = hssfworkbook.GetSheetAt(0);
  19. System.Collections.IEnumerator rows = sheet.GetRowEnumerator();
  20. DataTable dt = new DataTable();
  21. for (int j = 0; j < (sheet.GetRow(0).LastCellNum); j++)
  22. {
  23. dt.Columns.Add(Convert.ToChar(((int)'A') + j).ToString());
  24. }
  25. while (rows.MoveNext())
  26. {
  27. HSSFRow row = (HSSFRow)rows.Current;
  28. DataRow dr = dt.NewRow();
  29. for (int i = 0; i < row.LastCellNum; i++)
  30. {
  31. NPOI.SS.UserModel.Cell cell = row.GetCell(i);
  32. if (cell == null)
  33. {
  34. dr[i] = null;
  35. }
  36. else
  37. {
  38. dr[i] = cell.ToString();
  39. }
  40. }
  41. dt.Rows.Add(dr);
  42. }
  43. return dt;
  44. }
  45. #endregion

这样就可以读取一个EXCEL的文件了返回一个Datatable

asp.net DataTable导出 excel的方法记录(第三方)的更多相关文章

  1. asp.net中导出Excel的方法

    一.asp.net中导出Excel的方法: 本文转载 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出 ...

  2. asp.net DataTable导出Excel 自定义列名

    1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...

  3. ASP.NET导出excel表方法汇总

    asp.net里导出excel表方法汇总  1.由dataset生成 public void CreateExcel(DataSet ds,string typeid,string FileName) ...

  4. ASP.net中导出Excel的简单方法介绍

    下面介绍一种ASP.net中导出Excel的简单方法 先上代码:前台代码如下(这是自己项目里面写的一点代码先贴出来吧) <div id="export" runat=&quo ...

  5. asp.net中导出Execl的方法

    一.asp.net中导出Execl的方法: 在 asp.net中导出Execl有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址 输出在浏览器上:一种是将文件直接将文件输出流写给 ...

  6. ASP.NET MVC导出excel

    ASP.NET MVC导出excel 要在ASP.NET MVC站点上做excel导出功能,但是要导出的excel文件比较大,有几十M,所以导出比较费时,为了不影响对界面的其它操作,我就采用异步的方式 ...

  7. Datatable导出Excel

    ; IRow headerRow = sheet.CreateRow(); ; ; ; iRowIndex++; } ; i < icolIndex; i++) { sheet.AutoSize ...

  8. 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法

    -----转载:http://blog.csdn.net/sgear/article/details/7663502 关于asp.net C# 导出Excel文件 打开Excel文件格式与扩展名指定格 ...

  9. 懒人小工具:自动生成Model,Insert,Select,Delete以及导出Excel的方法

    在开发的过程中,我们为了节约时间,往往会将大量重复机械的代码封装,考虑代码的复用性,这样我们可以节约很多时间来做别的事情.最近跳槽到一节webform开发的公司,主要是开发自己公司用的ERP.开始因为 ...

随机推荐

  1. 第四章 深入JSP技术

    JSP简介 JSP工作原理 JSP是一种servlet,但先部署后编译. JSP生命周期 运行时只会有一个实例,同servlet. JSP语法 JSP元素和模板数据 模板数据就是JSP中的HTML代码 ...

  2. php缩略图

    /*引入文件Easyphpthumbnail.class.php 引用地址:http://www.itdaodan.com/article-detail-id-252.html */   class ...

  3. javascript之彻底理解this

    彻底理解this,需要彻底理解函数 函数是复杂类型,存储在堆中.  函数是独立的, 对象中的方法只是对象中有个函数的引用 函数被调用时,调用者会像被调用者提供个上下文环境, 这个环境就是this 构造 ...

  4. C#和Java在多态情况下对成员访问的比较

    本文简单比较一下两种语言在里氏替换原则下,父类引用变量访问成员时的访问结果: 如果有两个类,如Person与Student,后者继承了前者,而且子类与父类有重名成员,当Person p = new S ...

  5. Java JVM- jstat查看jvm的GC情况[转]

    ava通过jvm自己管理内存,同时Java提供了一些命令行工具,用于查看内存使用情况.这里主要介绍一下jstat.jmap命令以及相关工具. 一.jstat查看 gc实时执行情况 jstat命令命令格 ...

  6. iOS OC语言原生开发的IM模块--RChat

    iOS OC语言原生开发的IM模块,用于项目中需要原生开发IM的情况,具备发送文字.表情.语音.图片.视频等完整功能,包含图片预览视频播放等功能,此项目将会长期更新如有问题可以提出,我的邮箱:fshm ...

  7. git commad

    repo forall -c 'echo $REPO_PATH;ssh trd.git.htc.com -p29419 -lowen_wen gerrit create-project --submi ...

  8. NewCaffe

    NewCaffe

  9. 洛谷 P2055 [ZJOI2009]假期的宿舍

    洛谷 P2055 题目描述 学校放假了 · · · · · · 有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题.比如 A 和 B 都是学校的学生,A 要回家,而 C 来看B,C ...

  10. 口胡:[HNOI2011]数学作业

    题面 一开始看这题看了好久--觉得这题不可做. 结果是看错题了,我居然看着一段长长的C开头的单词,然后就觉得这是卡特兰数--不知道我在想些什么-- 观察到对于 i = 1~9 : f[i] = f[i ...