zoukankan      html  css  js  c++  java
  • ASP.NET操作Excel(终极方法NPOI)

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

    AD:2013大数据全球技术峰会课程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

  • 相关阅读:
    VBE2019、VBE2014、VBE2014_VB6三合一的下载、安装和使用(最新版2020.09.09)
    调用其他VBA工程中的过程和函数以及API函数
    QQ消息群发助手SendQQMessage的下载和使用
    VBA/VB6/VBS/VB.NET/C#/Python/PowerShell都能调用的API封装库
    Excel-DNA项目只用1个文件实现Ribbon CustomUI和CustomTaskpane定制【C#版】
    Excel-DNA项目只用1个文件实现Ribbon CustomUI和CustomTaskpane定制【VB.Net版】
    VSTO外接程序项目只用1个文件实现Ribbon CustomUI和CustomTaskpane定制【C#版】
    VSTO外接程序项目只用1个文件实现Ribbon CustomUI和CustomTaskpane定制【VB.Net版】
    Outlook邮件的右键菜单中添加自定义按钮
    VBA自动点击IE的浏览按钮、自动选择路径、自动关闭打开文件对话框
  • 原文地址:https://www.cnblogs.com/xyzhuzhou/p/3139651.html
Copyright © 2011-2022 走看看