NPOI导出Excel
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
#region NPOI
using NPOI.HSSF.UserModel;
using NPOI.HSSF.Util;
using NPOI.SS.UserModel;
using System.Web;
using System.IO;
using System.Data;
using System.Collections;
using System.Web.UI.WebControls;
#endregion
/*========================================================================================
*
*
* 说 明:导入、导出Excel
* 作 者:李朝强
* 日 期:2015/03/28
*
*
* =====================================================================================*/
namespace TiKu.Common.Office
{
public class Excel
{
#region ===============================================导出==================================
/// <summary>
/// 导出
/// </summary>
/// <param name="context">请求上下文</param>
/// <param name="fileName">导出文件的名</param>
/// <param name="stream">数据流</param>
public void Export(HttpContext context,
string fileName,
MemoryStream stream)
{
if (context.Request.Browser.Browser == "IE")
fileName = HttpUtility.UrlEncode(fileName);
context.Response.AddHeader("Content-Disposition", "attachment;fileName=" + fileName);
context.Response.BinaryWrite(stream.ToArray());
}
/// <summary>
/// 导出
/// </summary>
/// <param name="context">上下文</param>
/// <param name="filename">导出的文件名</param>
/// <param name="data">数据</param>
public void Export(HttpContext context,
string filename,
string sheetName,
Hashtable hashColumnInfos,
DataTable data)
{
MemoryStream ms = null;
try
{
ms = ReadToExcel(data,
sheetName,
hashColumnInfos);
//执行导出
Export(context, filename, ms);
}
catch (Exception ex) { throw ex; }
finally
{
if (null != ms)
{
ms.Close();
ms.Dispose();
}
}
}
/// <summary>
/// 从Repeat控件中,导出Excel
/// </summary>
/// <param name="RepList">控件</param>
/// <param name="filename">文件名</param>
/// <param name="sheetName">工作表</param>
public void Export(Repeater RepList,
string filename,
string sheetName,
HttpContext context)
{
object data = RepList.DataSource;
if (data is DataTable)
{
Export(context,
filename,
sheetName,
null,
(DataTable)data);
return;
}
if (data is DataView)
{
return;
}
if (data is IList)
{
return;
}
}
#endregion
#region ================================================数据流========================================
/// <summary>
/// 把DataTable对象,读取到内存流中
/// </summary>
/// <param name="data">DataTable对象</param>
/// <param name="hashColumnInfos">(可选)列</param>
/// <returns></returns>
public MemoryStream ReadToExcel(DataTable data,
string sheetName,
Hashtable hashColumnInfos)
{
sheetName = string.IsNullOrEmpty(sheetName) ? string.Format("Sheet-{0:yyy/MM/dd}", DateTime.Now) : sheetName;
//0>内存流
MemoryStream ms = new MemoryStream();
//1>创建工作薄
IWorkbook __workbook = new HSSFWorkbook();
//2>创建工作表
ISheet __sheet = __workbook.CreateSheet(sheetName);
#region 单元格样式
//单元格样式
ICellStyle cellStyle = __workbook.CreateCellStyle();
cellStyle.FillPattern = FillPattern.SolidForeground;
cellStyle.FillBackgroundColor = NPOI.HSSF.Util.HSSFColor.Green.Index;
//设置字体
IFont font = __workbook.CreateFont();
font.Color = NPOI.HSSF.Util.HSSFColor.White.Index;
cellStyle.SetFont(font);
cellStyle.FillForegroundColor = NPOI.HSSF.Util.HSSFColor.Green.Index;
#endregion
#region 3>创建表头
//创建一行
IRow __header = __sheet.CreateRow(0);
if (null == hashColumnInfos)
{
for (int i = 0; i < data.Columns.Count; i++)
{
//创建单元格
ICell __cell = __header.CreateCell(i);
__cell.SetCellValue(data.Columns[i].ColumnName);
__sheet.SetColumnWidth(i, 20 * 256);
__cell.CellStyle = cellStyle;
}
}
else
{
int j = 0;
foreach (DictionaryEntry item in hashColumnInfos)
{
//创建单元格
ICell __cell = __header.CreateCell(j);
__cell.SetCellValue(item.Value.ToString());
__sheet.SetColumnWidth(j, 20 * 256);
__cell.CellStyle = cellStyle;
++j;
}
}
#endregion
#region 4>创建数据行
int c = 0;
for (int k = 0; k < data.Rows.Count; k++)
{
IRow __dataRow = __sheet.CreateRow(k + 1);
for (c = 0; c < data.Columns.Count; c++)
{
ICell iCell = __dataRow.CreateCell(c);
iCell.SetCellValue(data.Rows[k][data.Columns[c].ColumnName].ToString());
c++;
}
c = 0;
}
#endregion
//5>最后,写入内存流
__workbook.Write(ms);
return ms;
}
/// <summary>
/// 把IDataReader对象,读取到内存流中
/// </summary>
/// <param name="dataReader">IDataReader对象</param>
/// <param name="sheetName">工作表名称</param>
/// <param name="hashColumnInfos">列</param>
/// <returns></returns>
public MemoryStream ReadToExcel(IDataReader dataReader,
string sheetName,
Hashtable hashColumnInfos)
{
//0>内存流
MemoryStream ms = new MemoryStream();
//1>创建工作薄
IWorkbook __workbook = new HSSFWorkbook();
//2>创建工作表
ISheet __sheet = __workbook.CreateSheet(sheetName);
#region 3>表头
IRow __header = __sheet.CreateRow(0);
if (null == hashColumnInfos)
{
for (int i = 0; i < dataReader.FieldCount; i++)
{
ICell iHeaderCell = __header.CreateCell(i);
iHeaderCell.SetCellValue(dataReader.GetName(i));
}
}
else
{
int j = 0;
foreach (DictionaryEntry item in hashColumnInfos)
{
//创建单元格
ICell __cell = __header.CreateCell(j);
__cell.SetCellValue(item.Value.ToString());
++j;
}
}
#endregion
#region 4>数据行
int n = 1;
while (dataReader.Read())
{
IRow __dataRow = __sheet.CreateRow(n);
for (int c = 0; c < dataReader.FieldCount; c++)
{
ICell iCell = __dataRow.CreateCell(c);
iCell.SetCellValue((dataReader.GetValue(c) ?? "").ToString());
}
}
#endregion
//5>写入内存流
__workbook.Write(ms);
return ms;
}
#endregion
}
}
NPOI导出Excel的更多相关文章
- NPOI导出Excel (C#) 踩坑 之--The maximum column width for an individual cell is 255 charaters
/******************************************************************* * 版权所有: * 类 名 称:ExcelHelper * 作 ...
- Asp.Net 使用Npoi导出Excel
引言 使用Npoi导出Excel 服务器可以不装任何office组件,昨天在做一个导出时用到Npoi导出Excel,而且所导Excel也符合规范,打开时不会有任何文件损坏之类的提示.但是在做导入时还是 ...
- NPOI导出EXCEL 打印设置分页及打印标题
在用NPOI导出EXCEL的时候设置分页,在网上有查到用sheet1.SetRowBreak(i)方法,但一直都没有起到作用.经过研究是要设置 sheet1.FitToPage = false; 而 ...
- .NET NPOI导出Excel详解
NPOI,顾名思义,就是POI的.NET版本.那POI又是什么呢?POI是一套用Java写成的库,能够帮助开发者在没有安装微软Office的情况下读写Office的文件. 支持的文件格式包括xls, ...
- NPOI导出Excel(含有超过65335的处理情况)
NPOI导出Excel的网上有很多,正好自己遇到就学习并总结了一下: 首先说明几点: 1.Excel2003及一下:后缀xls,单个sheet最大行数为65335 Excel2007 单个sheet ...
- [转]NPOI导出EXCEL 打印设置分页及打印标题
本文转自:http://www.cnblogs.com/Gyoung/p/4483475.html 在用NPOI导出EXCEL的时候设置分页,在网上有查到用sheet1.SetRowBreak(i)方 ...
- 分享使用NPOI导出Excel树状结构的数据,如部门用户菜单权限
大家都知道使用NPOI导出Excel格式数据 很简单,网上一搜,到处都有示例代码. 因为工作的关系,经常会有处理各种数据库数据的场景,其中处理Excel 数据导出,以备客户人员确认数据,场景很常见. ...
- 用NPOI导出Excel
用NPOI导出Excel public void ProcessRequest(HttpContext context) { context.Response.ContentType = " ...
- NPOI导出Excel示例
摘要:使用开源程序NPOI导出Excel示例.NPOI首页地址:http://npoi.codeplex.com/,NPOI示例博客:http://tonyqus.sinaapp.com/. 示例编写 ...
- NPOI导出excel(带图片)
近期项目中用到Excel导出功能,之前都是用普通的office组件导出的方法,今天尝试用下NPOI,故作此文以备日后查阅. 1.NPOI官网http://npoi.codeplex.com/,下载最新 ...
随机推荐
- SQLServer执行命令出现“目录无效的提示”
异常处理汇总-数据库系列 http://www.cnblogs.com/dunitian/p/4522990.html 一般都是清理垃圾清理过头了,把不该删的目录删了 网上说法: 问题描述: 1.s ...
- [C#] string 与 String,大 S 与小 S 之间没有什么不可言说的秘密
string 与 String,大 S 与小 S 之间没有什么不可言说的秘密 目录 小写 string 与大写 String 声明与初始化 string string 的不可变性 正则 string ...
- 拼图小游戏之计算后样式与CSS动画的冲突
先说结论: 前几天写了几个非常简单的移动端小游戏,其中一个拼图游戏让我郁闷了一段时间.因为要获取每张图片的位置,用`<style>`标签写的样式,直接获取计算后样式再用来交换位置,结果就悲 ...
- BPM配置故事之案例9-根据表单数据调整审批线路2
老李:好久不见啊,小明. 小明:-- 老李:不少部门有物资着急使用,现在的审批流程太慢了,申请时增加一个是否加急的选项吧.如果选加急,金额1000以下的直接到我这里,我审批完就通过,超过1000的直接 ...
- (转)从0开始搭建SQL Server AlwaysOn 第一篇(配置域控+域用户DCADMIN)
原文地址: http://www.cnblogs.com/lyhabc/p/4678330.html 实验环境: 准备工作 软件准备 (1) SQL Server 2012 (2) Windows S ...
- Jenkins的一个bug-同时build一个项目两次导致失败
我们有一个job A, A只是配置了一些参数,它会去触发模板job B. 我一开始点击构建A, 马上发现参数配置不对,于是撤消了构建,但是我没有发现B已经被触发,我重新配置参数,然后再次构建A,这个时 ...
- PHP安装
工具 http://www.cnblogs.com/xiwang6428/p/4315049.html http://www.iteye.com/news/22672 1 安装:sudo apt-ge ...
- springMvc的日期转换之二
方式一:使用@InitBinder注解实现日期转换 前台页面: 后台打印: 方式二:处理多种日期格式类型之间的转换 采用方式:由于binder.registerCustomEditor(Date.cl ...
- CYQ.Data V5 从入门到放弃ORM系列:教程 - MProc类使用
MProc介绍 MProc:是一个用于执行SQL或存储过程的数据库操作类,它轻量高性能地类似于Dapper. MProc:它出现的场景很少,因为MAction自身就能处理掉90%-100%的数据操作( ...
- ASP.NET 5 Beta 8 发布
ASP.NET 5 的路线图(详见 ASP.NET 5 Schedule and Roadmap : https://github.com/aspnet/home/wiki/roadmap ):Bet ...