前段时间客户要求网页上显示的报表能导出成Excel文件,而且要求Excel有好看的样式,虽然导出Excel的方式很多,但是都达不到要求,后来在网上找到使用NPOI组件的方式导出,自己进行调试,发现完全可以达到要求,为了使用方便和客户以后的需求,自己写了几个类对NPOI提供的方法进行了加工,代码如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
//导出excel 相关
using System.IO;
using System.Data;
using System.Web;
using NPOI;
using NPOI.HSSF.Model;
using NPOI.POIFS.FileSystem;
using NPOI.HSSF.UserModel;
using NPOI.HSSF.Record;
using NPOI.HSSF.Util;
//
using System.Web.UI.WebControls;
namespace Eap.Utils
{
#region 字体样式模板/************************************************************************/
/* 字体样式模板默认样式 */
/************************************************************************/
public class FontDefaultTemplate
{
public FontDefaultTemplate(HSSFWorkbook hSSFWorkbook)
{
mHSSFFont = hSSFWorkbook.CreateFont();mHSSFFont.FontName = "微软雅黑"; //字体类型
mHSSFFont.FontHeightInPoints = 18; //字号
mHSSFFont.Boldweight = HSSFFont.BOLDWEIGHT_NORMAL; //字形 普通
mHSSFFont.Color = HSSFColor.BLACK.index; //字体颜色
mHSSFFont.Underline = HSSFFont.U_NONE; //下划线 无
mHSSFFont.IsItalic = false; //斜体 无
mHSSFFont.IsStrikeout = false; //删除线 无}
public HSSFFont FontDefaultStyle
{
get { return mHSSFFont; }
}private HSSFFont mHSSFFont;
}/************************************************************************/
/* 字体样式模板 */
/************************************************************************/
public static class HSSFFontTemplates
{
/// <summary>
/// 大标题1
/// </summary>
/// <param name="hSSFWorkbook">HSSFWorkbook</param>
/// <returns>HSSFFont</returns>
public static HSSFFont FontTitle1(HSSFWorkbook hSSFWorkbook)
{
FontDefaultTemplate fontDefaultTemplate = new FontDefaultTemplate(hSSFWorkbook);
HSSFFont font = fontDefaultTemplate.FontDefaultStyle;return font;
}/// <summary>
/// 大标题2
/// </summary>
/// <param name="hSSFWorkbook">HSSFWorkbook</param>
/// <returns>HSSFFont</returns>
public static HSSFFont FontTitle2(HSSFWorkbook hSSFWorkbook)
{
FontDefaultTemplate fontDefaultTemplate = new FontDefaultTemplate(hSSFWorkbook);
HSSFFont font = fontDefaultTemplate.FontDefaultStyle;font.FontHeightInPoints = 11; //字号
font.Color = HSSFColor.BLUE.index; //字体颜色return font;
}/// <summary>
/// 列标题1
/// </summary>
/// <param name="hSSFWorkbook">HSSFWorkbook</param>
/// <returns>HSSFFont</returns>
public static HSSFFont FontColTitle1(HSSFWorkbook hSSFWorkbook)
{
FontDefaultTemplate fontDefaultTemplate = new FontDefaultTemplate(hSSFWorkbook);
HSSFFont font = fontDefaultTemplate.FontDefaultStyle;font.FontHeightInPoints = 11; //字号
font.Boldweight = HSSFFont.BOLDWEIGHT_BOLD; //字形 加粗return font;
}/// <summary>
/// 内容1
/// </summary>
/// <param name="hSSFWorkbook">
在NET中使用NPOI导出Excel
最新推荐文章于 2024-10-16 22:42:21 发布
本文介绍了如何使用NPOI组件在.NET环境中创建和导出带有样式的Excel文件。通过定义字体样式模板和单元格样式模板,实现了不同类型的标题和内容样式。此外,还展示了如何创建表格数据并导出到Excel,以及如何设置列宽和标题。最后,给出了两个实际的报表导出示例,分别是学习进度报表和课程明细报表。
摘要由CSDN通过智能技术生成