官网: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. springboot+vue+element:echarts开发遇见问题---后端sql(三)

    <select id="getSumRequestRankingCount" parameterType="java.lang.String" resul ...

  2. lintcode-511-交换链表当中两个节点

    511-交换链表当中两个节点 给你一个链表以及两个权值v1和v2,交换链表中权值为v1和v2的这两个节点.保证链表中节点权值各不相同,如果没有找到对应节点,那么什么也不用做. 注意事项 你需要交换两个 ...

  3. 【转载】mysql建表date类型不能设置默认值

    如题,mysql建表date类型的不能设置一个默认值,比如我这样: CREATE TABLE `new_table` ( `biryhday` datetime NULL DEFAULT '1996- ...

  4. CentOS 7 U盘安装问题解决

    最近期待以久的CentOS 7正式版终于发布了,在家里无聊,所以就打算在我的小Y上安装一下,由于笔记本原来有安装Windows 7 操作系统,考虑使用的需求,所以决定安装双系统: 1.         ...

  5. BZOJ 2007 海拔(平面图最小割转对偶图最短路)

    首先注意到,把一个点的海拔定为>1的数是毫无意义的.实际上,可以转化为把这些点的海拔要么定为0,要么定为1. 其次,如果一个点周围的点的海拔没有和它相同的,那么这个点的海拔也是可以优化的,即把这 ...

  6. 【bzoj3456】城市规划 容斥原理+NTT+多项式求逆

    题目描述 求出n个点的简单(无重边无自环)无向连通图数目mod 1004535809(479 * 2 ^ 21 + 1). 输入 仅一行一个整数n(<=130000) 输出 仅一行一个整数, 为 ...

  7. BZOJ4950 Wf2017Mission Improbable(二分图匹配)

    先给每个非零格子-1以满足俯视图不变.于是就相当于要求每行每列最大值不变.能减少剩余箱子的唯一方法是在要求相同的行列的交叉处放箱子以同时满足两个需求.给这些行列连边跑二分图匹配即可.注意必须格子初始时 ...

  8. BZOJ3591 最长上升子序列(状压dp)

    之前听说过一种dp套dp的trick,大致是用另一个dp过程中用到的一些东西作为该dp的状态.这个题比较类似. 考虑求LIS时用到的单调队列.设f[S]为所选取集合为S的方案数,其中在单调队列内的标2 ...

  9. C++解析(21):四个操作符

    0.目录 1.逻辑操作符的陷阱 2.逗号操作符的分析 3.前置操作符和后置操作符 4.小结 1.逻辑操作符的陷阱 逻辑运算符的原生语义: 操作数只有两种值(true和false) 逻辑表达式不用完全计 ...

  10. 在 Xamarin.Forms 实现页面全屏显示

    NavigationPage.SetHasNavigationBar(this, false); 或者 <ContentPage ... NavigationPage.HasNavigation ...