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

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值