在NET中使用NPOI导出Excel

本文介绍了如何使用NPOI组件在.NET环境中创建和导出带有样式的Excel文件。通过定义字体样式模板和单元格样式模板,实现了不同类型的标题和内容样式。此外,还展示了如何创建表格数据并导出到Excel,以及如何设置列宽和标题。最后,给出了两个实际的报表导出示例,分别是学习进度报表和课程明细报表。
摘要由CSDN通过智能技术生成

前段时间客户要求网页上显示的报表能导出成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">

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值