C# 使用NPOI生成Excel文件——合并单元格、设置Style


using System;
using System.IO;
using NPOI.HSSF;
using NPOI.HPSF;
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;

//导出常用方法示例(使用该方法时需先引入NPOI.dll文件):
class Program{
    public static void Main(string[] args){
        ExportExcel();
    }

    /// <summary>
    /// 导出基本操作示例方法
    /// </summary>
    public static void ExportExcel(){
        //初始化一个新的HSSFWorkbook实例
        HSSFWorkbook hssfworkbook = new HSSFWorkbook();

        //设置excel必须的文件属性(该属性用来存储 如作者、标题、标记、备注、主题等信息,右键可查看的属性信息)
        DocumentSummaryInformation dsi = PropertySetFactory.CreateDocumentSummaryInformation();
        dsi.Company = "NPOI Team";
        SummaryInformation si = PropertySetFactory.CreateSummaryInformation();
        si.Subject = "NPOI SDK Example";
        hssfworkbook.DocumentSummaryInformation = dsi;
        hssfworkbook.SummaryInformation = si;


        //新建一个Workbook默认都会新建3个Sheet(标准的Excel文件有3个Sheet)。所以必须加入下面的创建Sheet的代码才能保证生成的文件正常
        HSSFSheet sheet = (HSSFSheet)hssfworkbook.CreateSheet("new sheet");
        // hssfworkbook.CreateSheet("Sheet1");
        // hssfworkbook.CreateSheet("Sheet2");
        // hssfworkbook.CreateSheet("Sheet3");

        //建创行
        IRow row1=sheet.CreateRow(0);
        //建单元格,比如创建A1位置的单元格:
        row1.CreateCell(0).SetCellValue(1);
        //简写 shee1.CreateRow(0).CreateCell(0).SetCellValue("This is a Sample");

        //把C3:E5合并为一个单元格 并赋值
        ICell cell= sheet.CreateRow(2).CreateCell(2);
        cell.SetCellValue("This is a Sample");
        sheet.AddMergedRegion(new NPOI.SS.Util.Region(2, 2, 4, 4));

        //设置样式 居中 字体
        ICellStyle style = hssfworkbook.CreateCellStyle();
        style.VerticalAlignment = VerticalAlignment.Center;
        style.Alignment = HorizontalAlignment.Center;
        IFont font = hssfworkbook.CreateFont();
        font.FontHeight = 20 * 20;
        style.SetFont(font);
        cell.CellStyle = style;

        //把这个HSSFWorkbook实例写入文件
        FileStream file = new FileStream("Example1.xls", FileMode.Create);
        hssfworkbook.Write(file);
        file.Close();
    }
    
    public static string now(){
        return DateTime.Now.ToString("HH:mm:ss.fff");
    }
}

  本文转自开源博客,链接:https://my.oschina.net/u/1242247/blog/2990403,原创:devcang


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM