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;
    }
}

 

目录
相关文章
|
1月前
|
NoSQL 关系型数据库 MySQL
多人同时导出 Excel 干崩服务器?怎样实现一个简单排队导出功能!
业务诉求:考虑到数据库数据日渐增多,导出会有全量数据的导出,多人同时导出可以会对服务性能造成影响,导出涉及到mysql查询的io操作,还涉及文件输入、输出流的io操作,所以对服务器的性能会影响的比较大;结合以上原因,对导出操作进行排队; 刚开始拿到这个需求,第一时间想到就是需要维护一个FIFO先进先出的队列,给定队列一个固定size,在队列里面的人进行排队进行数据导出,导出完成后立马出队列,下一个排队的人进行操作;还考虑到异步,可能还需要建个文件导出表,主要记录文件的导出情况,文件的存放地址,用户根据文件列表情况下载导出文件。
多人同时导出 Excel 干崩服务器?怎样实现一个简单排队导出功能!
|
3月前
|
Java Apache Spring
springboot如何导出Excel某个表的表字段以及字段类型
springboot如何导出Excel某个表的表字段以及字段类型
32 0
|
3月前
|
关系型数据库 MySQL 数据库连接
python查询数据库的某个表,将结果导出Excel
python查询数据库的某个表,将结果导出Excel
46 0
|
2月前
|
XML Java 数据格式
使用Freemarker模版导出xls文件使用excel打开提示文件损坏
使用Freemarker模版导出xls文件使用excel打开提示文件损坏
49 0
|
1月前
|
SQL Java easyexcel
【Java】百万数据excel导出功能如何实现
【Java】百万数据excel导出功能如何实现
118 0
|
2月前
|
Java
使用POI导出Excel
使用POI导出Excel
|
2月前
|
前端开发 Java Maven
springboot优雅的实现excel的导出(自适应列宽实现,中文也行),复制可用
springboot优雅的实现excel的导出(自适应列宽实现,中文也行),复制可用
57 0
|
2月前
|
测试技术 数据处理 Python
测试报告导出PDF和excel的方法
测试报告导出PDF和excel的方法
|
3月前
|
Python
python如何导出Excel某个表的表字段以及字段类型
python如何导出Excel某个表的表字段以及字段类型
24 0