ASP.NET使用NPOI类库导出Excel

简介: /* * 作者: 牛腩 * 创建时间: 2010-1-4 15:15:05 * Email: 164423073@qq.com * 说明: 导出EXCEL的类,使用说明见:http://msdn.microsoft.
/*
 * 作者: 牛腩
 * 创建时间: 2010-1-4 15:15:05
 * Email: 164423073@qq.com
 * 说明: 导出EXCEL的类,使用说明见:
http://msdn.microsoft.com/zh-tw/ee818993.aspx
 
*/

using  System;
using  System.Collections.Generic;
using  System.Data;
using  System.IO;
using  System.Linq;
using  System.Web;
using  NPOI;
using  NPOI.HPSF;
using  NPOI.HSSF;
using  NPOI.HSSF.UserModel;
using  NPOI.POIFS;
using  NPOI.Util;

public   class  DataTableRenderToExcel
{
    
public   static  Stream RenderDataTableToExcel(DataTable SourceTable)
    {
        HSSFWorkbook workbook 
=   new  HSSFWorkbook();
        MemoryStream ms 
=   new  MemoryStream();
        HSSFSheet sheet 
=  workbook.CreateSheet();
        HSSFRow headerRow 
=  sheet.CreateRow( 0 );

        
//  handling header.
         foreach  (DataColumn column  in  SourceTable.Columns)
            headerRow.CreateCell(column.Ordinal).SetCellValue(column.ColumnName);

        
//  handling value.
         int  rowIndex  =   1 ;

        
foreach  (DataRow row  in  SourceTable.Rows)
        {
            HSSFRow dataRow 
=  sheet.CreateRow(rowIndex);

            
foreach  (DataColumn column  in  SourceTable.Columns)
            {
                dataRow.CreateCell(column.Ordinal).SetCellValue(row[column].ToString());
            }

            rowIndex
++ ;
        }

        workbook.Write(ms);
        ms.Flush();
        ms.Position 
=   0 ;

        sheet 
=   null ;
        headerRow 
=   null ;
        workbook 
=   null ;

        
return  ms;
    }

    
public   static   void  RenderDataTableToExcel(DataTable SourceTable,  string  FileName)
    {
        MemoryStream ms 
=  RenderDataTableToExcel(SourceTable)  as  MemoryStream;
        FileStream fs 
=   new  FileStream(FileName, FileMode.Create, FileAccess.Write);
        
byte [] data  =  ms.ToArray();

        fs.Write(data, 
0 , data.Length);
        fs.Flush();
        fs.Close();

        data 
=   null ;
        ms 
=   null ;
        fs 
=   null ;
    }

    
public   static  DataTable RenderDataTableFromExcel(Stream ExcelFileStream,  string  SheetName,  int  HeaderRowIndex)
    {
        HSSFWorkbook workbook 
=   new  HSSFWorkbook(ExcelFileStream);
        HSSFSheet sheet 
=  workbook.GetSheet(SheetName);

        DataTable table 
=   new  DataTable();

        HSSFRow headerRow 
=  sheet.GetRow(HeaderRowIndex);
        
int  cellCount  =  headerRow.LastCellNum;

        
for  ( int  i  =  headerRow.FirstCellNum; i  <  cellCount; i ++ )
        {
            DataColumn column 
=   new  DataColumn(headerRow.GetCell(i).StringCellValue);
            table.Columns.Add(column);
        }

        
int  rowCount  =  sheet.LastRowNum;

        
for  ( int  i  =  (sheet.FirstRowNum  +   1 ); i  <  sheet.LastRowNum; i ++ )
        {
            HSSFRow row 
=  sheet.GetRow(i);
            DataRow dataRow 
=  table.NewRow();

            
for  ( int  j  =  row.FirstCellNum; j  <  cellCount; j ++ )
                dataRow[j] 
=  row.GetCell(j).ToString();
        }

        ExcelFileStream.Close();
        workbook 
=   null ;
        sheet 
=   null ;
        
return  table;
    }

    
public   static  DataTable RenderDataTableFromExcel(Stream ExcelFileStream,  int  SheetIndex,  int  HeaderRowIndex)
    {
        HSSFWorkbook workbook 
=   new  HSSFWorkbook(ExcelFileStream);
        HSSFSheet sheet 
=  workbook.GetSheetAt(SheetIndex);

        DataTable table 
=   new  DataTable();

        HSSFRow headerRow 
=  sheet.GetRow(HeaderRowIndex);
        
int  cellCount  =  headerRow.LastCellNum;

        
for  ( int  i  =  headerRow.FirstCellNum; i  <  cellCount; i ++ )
        {
            DataColumn column 
=   new  DataColumn(headerRow.GetCell(i).StringCellValue);
            table.Columns.Add(column);
        }

        
int  rowCount  =  sheet.LastRowNum;

        
for  ( int  i  =  (sheet.FirstRowNum  +   1 ); i  <  sheet.LastRowNum; i ++ )
        {
            HSSFRow row 
=  sheet.GetRow(i);
            DataRow dataRow 
=  table.NewRow();

            
for  ( int  j  =  row.FirstCellNum; j  <  cellCount; j ++ )
            {
                
if  (row.GetCell(j)  !=   null )
                    dataRow[j] 
=  row.GetCell(j).ToString();
            }

            table.Rows.Add(dataRow);
        }

        ExcelFileStream.Close();
        workbook 
=   null ;
        sheet 
=   null ;
        
return  table;
    }

    
///   <summary> 读取excel
    
///  默认第一行为标头
    
///   </summary>
    
///   <param name="path"> excel文档路径 </param>
    
///   <returns></returns>
     public   static  DataTable RenderDataTableFromExcel( string  path) {
        DataTable dt 
=   new  DataTable();

        HSSFWorkbook hssfworkbook;
        
using  (FileStream file  =   new  FileStream(path, FileMode.Open, FileAccess.Read))
        {
            hssfworkbook 
=   new  HSSFWorkbook(file);
        }
        HSSFSheet sheet 
=  hssfworkbook.GetSheetAt( 0 );
        System.Collections.IEnumerator rows 
=  sheet.GetRowEnumerator();

        HSSFRow headerRow 
=  sheet.GetRow( 0 );
        
int  cellCount  =  headerRow.LastCellNum;

        
for  ( int  j  =   0 ; j  <  cellCount; j ++ )
        {
            HSSFCell cell 
=  headerRow.GetCell(j);
            dt.Columns.Add(cell.ToString());
        }

        
for  ( int  i  =  (sheet.FirstRowNum  +   1 ); i  <=  sheet.LastRowNum; i ++ )
        {
            HSSFRow row 
=  sheet.GetRow(i);
            DataRow dataRow 
=  dt.NewRow();

            
for  ( int  j  =  row.FirstCellNum; j  <  cellCount; j ++ )
            {
                
if  (row.GetCell(j)  !=   null )
                    dataRow[j] 
=  row.GetCell(j).ToString();
            }

            dt.Rows.Add(dataRow);
        }

        
// while (rows.MoveNext())
        
// {
        
//     HSSFRow row = (HSSFRow)rows.Current;
        
//     DataRow dr = dt.NewRow();

        
//     for (int i = 0; i < row.LastCellNum; i++)
        
//     {
        
//         HSSFCell cell = row.GetCell(i);


        
//         if (cell == null)
        
//         {
        
//             dr[i] = null;
        
//         }
        
//         else
        
//         {
        
//             dr[i] = cell.ToString();
        
//         }
        
//     }
        
//     dt.Rows.Add(dr);
        
// }

        
return  dt;
    }
}

 

目录
相关文章
|
开发框架 算法 .NET
一个简单高效低内存的.NET操作Excel开源框架 - MiniExcel
一个简单高效低内存的.NET操作Excel开源框架 - MiniExcel
467 0
|
缓存 算法 安全
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
712 12
|
机器学习/深度学习 人工智能 Cloud Native
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台。本文深入解析 .NET 的核心优势,探讨其在企业级应用、Web 开发及移动应用等领域的应用案例,并展望未来在人工智能、云原生等方面的发展趋势。
430 3
|
开发框架 .NET Linux
2款高效的.NET二维码生成类库
2款高效的.NET二维码生成类库
335 1
|
存储 对象存储 Python
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
`openpyxl`是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库。它不需要Microsoft Excel,也不需要.NET或COM组件。
|
人工智能 开发框架 Devops
.NET技术概览:** 本文探讨了.NET的核心特性,包括多语言支持、Common Language Runtime、丰富的类库和跨平台能力,强调其在企业级、Web、移动及游戏开发中的应用。
【7月更文挑战第4天】.NET技术概览:** 本文探讨了.NET的核心特性,包括多语言支持、Common Language Runtime、丰富的类库和跨平台能力,强调其在企业级、Web、移动及游戏开发中的应用。此外,讨论了.NET如何通过性能优化、DevOps集成、AI与ML支持以及开源策略应对未来挑战,为开发者提供强大工具,共创软件开发新篇章。
581 3
|
人工智能 前端开发 Devops
NET技术在现代开发中的影响力日益增强,本文聚焦其核心价值,如多语言支持、强大的Visual Studio工具、丰富的类库和跨平台能力。
【7月更文挑战第4天】**.NET技术在现代开发中的影响力日益增强,本文聚焦其核心价值,如多语言支持、强大的Visual Studio工具、丰富的类库和跨平台能力。实际应用涵盖企业系统、Web、移动和游戏开发,以及云服务。面对性能挑战、容器化、AI集成及跨平台竞争,.NET持续创新,开发者应关注技术趋势,提升技能,并参与社区,共同推进技术发展。**
273 1
|
开发框架 .NET API
分享一个 ASP.NET Web Api 上传和读取 Excel的方案
分享一个 ASP.NET Web Api 上传和读取 Excel的方案
535 0
|
XML 开发框架 数据格式
.Net Core 开发框架,支持多版本的类库
.Net Core 开发框架,支持多版本的类库
411 0
|
开发框架 .NET API
.NET Core 和 .NET 标准类库项目类型有什么区别?
在 Visual Studio 中,可创建三种类库:.NET Framework、.NET Standard 和 .NET Core。.NET Standard 是规范,确保跨.NET实现的API一致性,适用于代码共享。.NET Framework 用于特定技术,如旧版支持。.NET Core 库允许访问更多API但限制兼容性。选择取决于兼容性和所需API:需要广泛兼容性时用.NET Standard,需要更多API时用.NET Core。.NET Standard 替代了 PCL,促进多平台共享代码。
372 0