官网: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. Alpha 冲刺7

    队名:日不落战队 安琪(队长) 今天完成的任务 完善回收站. 学习okhttp. 明天的计划 继续研究okhttp. 尝试登录的数据对接. 还剩下的任务 个人信息对接. 遇到的困难 今天白天焊接,晚上 ...

  2. 【BioCode】删除未算出PSSM与SS的蛋白质序列

    代码说明: 由于一些原因(氨基酸序列过长),没有算出PSSM与SS,按照整理出来的未算出特征的文件,删除原来的蛋白质序列: 需删除的氨基酸文件732.txt(共732条氨基酸): 删除前 氨基酸共25 ...

  3. Python入门:认识变量和字符串

    几个月前,我开始学习个人形象管理,从发型.妆容.服饰到仪表仪态,都开始做全新改造,在塑造个人风格时,最基础的是先了解自己属于哪种风格,然后找到参考对象去模仿,可以是自己欣赏的人.明星或模特等,直至最后 ...

  4. 这可能是目前最全的Redis高可用技术解决方案总结

    本文主要针对 Redis 常见的几种使用方式及其优缺点展开分析. 一.常见使用方式 Redis 的几种常见使用方式包括: Redis 单副本: Redis 多副本(主从): Redis Sentine ...

  5. 关于SIGPIPE信号

    对一个对端已经关闭的socket调用两次write, 第二次将会生成SIGPIPE信号, 该信号默认结束进程.具体的分析可以结合TCP的"四次握手"关闭. TCP是全双工的信道, ...

  6. 【转】Base64算法详解

    原文链接:https://blog.csdn.net/robertcpp/article/details/51628647 完整的BASE64定义可见RFC 1421和RFC 2045.编码后的数据比 ...

  7. 利用SSH secure Shell实现windows与linux之间传输文件

    在windows下安装SSH secure Shell.默认安装后有两个快捷方式. linux下需要安装openssh-server utuntu默认安装了opens是-client,所以不需要安装, ...

  8. RxSwift基本使用(一)

    备注:本文参考自田腾飞博文 [RxSwift入坑解读-你所需要知道的各种概念] (http://www.codertian.com/2016/11/27/RxSwift-ru-keng-ji-read ...

  9. Hadoop基于Protocol Buffer的RPC实现代码分析-Server端--转载

    原文地址:http://yanbohappy.sinaapp.com/?p=110 最新版本的Hadoop代码中已经默认了Protocol buffer(以下简称PB,http://code.goog ...

  10. hdu3507 Print Article(斜率优化入门)(pascal)

    Problem Description Zero has an old printer that doesn't work well sometimes. As it is antique, he s ...