【.NET Core】Excel操作(NPOI)

NPOI简介

NPOI就是POI的.NET版本,NPOI能够帮助我们在没有安装微软Office的情况下读写Office文件,如xls, doc, ppt等。

NPOI源码

https://github.com/nissl-lab/npoi

Nuget

install-package NPOI

入门

生成一个Excel文件

using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;

{
    //创建工作簿
    using (IWorkbook workbook = new HSSFWorkbook())
    {
        //创建sheet页
        ISheet sheet1 = workbook.CreateSheet("sheet1");
        //创建第一行
        {
            IRow header = sheet1.CreateRow(0);
            //创建单元格
            ICell cell1 = header.CreateCell(0);
            cell1.SetCellValue("ID");
            ICell cell2 = header.CreateCell(1);
            cell2.SetCellValue("姓名");
            ICell cell3 = header.CreateCell(2);
            cell3.SetCellValue("年龄");
            ICell cell4 = header.CreateCell(3);
            cell4.SetCellValue("数学成绩");
            ICell cell5 = header.CreateCell(4);
            cell5.SetCellValue("语文成绩");
        }
        //创建第二行
        {
            IRow row = sheet1.CreateRow(1);
            ICell cell1 = row.CreateCell(0);
            cell1.SetCellValue(1);
            ICell cell2 = row.CreateCell(1);
            cell2.SetCellValue("fan1");
            ICell cell3 = row.CreateCell(2);
            cell3.SetCellValue(18);
            ICell cell4 = row.CreateCell(3);
            cell4.SetCellValue(99.5);
            ICell cell5 = row.CreateCell(4);
            cell5.SetCellValue(100);
        }
        //导出
        var path = Path.Combine(Directory.GetCurrentDirectory(), "test.xls");
        using (var fs = new FileStream(path, FileMode.Create))
        {
            workbook.Write(fs, true);
        }
    }

}

单元格数据格式

在Excel中我们经常要设置格式,比如说日期格式(2018-1-1)、小数点格式(1.20)、货币格式($2000)、百分比格式(99.99%)等等,这些东西在过去我们恐怕只能在服务器端生成好,不但增加了服务器端的代码量,还造成了不必要的字符串替换操作,如今NPOI将让服务器从这种完全没有必要的操作中解放出来,一切都将由Excel在客户端处理。
所有的格式都是通过 CellStyle.DataFormat 赋给单元格的,而不是直接赋给单元格,设置单元格数据展示的格式有两种方法。

excel内部设置了很多格式,如下图所示:

使用内置格式

如果我们想使用这些内置的格式,可用通过 DataFormat.GetBuildinFormat('格式') 来使用,使用实例如下:

cellStyle.DataFormat = HSSFDataFormat.GetBuiltinFormat("0.00");  //两位小数,内置格式

使用自定义格式

有时候内置的格式不能满足我们的要求,这时候就可以使用 workbook.CreateDataFormat().GetFormat("格式") 自定义格式了,使用语法如下:

cellStyle.DataFormat= workbook.CreateDataFormat().GetFormat("yyyy年m月d日 hh时mm分ss秒");//显示中文日期和时间,自定义格式

数据格式案例

{
    IWorkbook workbook = new HSSFWorkbook();
    ISheet sheet = workbook.CreateSheet("new sheet");
    //设置日期格式,2018年5月5日格式
    ICell cell = sheet.CreateRow(0).CreateCell(0);
    cell.SetCellValue(new DateTime(2018, 5, 5, 11, 31, 56));
    ICellStyle cellStyle = workbook.CreateCellStyle();
    cellStyle.DataFormat = workbook.CreateDataFormat().GetFormat("yyyy年m月d日 hh时mm分ss秒");
    //cellStyle.DataFormat = workbook.CreateDataFormat().GetFormat("yyyy/mm/dd hh:mm:ss"); 
    cell.CellStyle = cellStyle;

    //保留2位小数
    ICell cell2 = sheet.CreateRow(1).CreateCell(0);
    cell2.SetCellValue(12.346666);
    ICellStyle cellStyle2 = workbook.CreateCellStyle();
    cellStyle2.DataFormat = HSSFDataFormat.GetBuiltinFormat("0.00");
    cell2.CellStyle = cellStyle2;

    //货币格式
    ICell cell3 = sheet.CreateRow(2).CreateCell(0);
    cell3.SetCellValue(1234.66666);
    ICellStyle cellStyle3 = workbook.CreateCellStyle();
    cellStyle3.DataFormat = workbook.CreateDataFormat().GetFormat("¥#,##0.00");//美元的话格式为 $#,##0.00,其中#,##0表示千分号
    cell3.CellStyle = cellStyle3;

    //百分比
    ICell cell4 = sheet.CreateRow(3).CreateCell(0);
    cell4.SetCellValue(1.236666);
    ICellStyle cellStyle4 = workbook.CreateCellStyle();
    //cellStyle4.DataFormat = HSSFDataFormat.GetBuiltinFormat("0.00%");//保留两位小数
    cellStyle4.DataFormat = HSSFDataFormat.GetBuiltinFormat("0%");
    cell4.CellStyle = cellStyle4;

    //中文大写数字
    ICell cell5 = sheet.CreateRow(4).CreateCell(0);
    cell5.SetCellValue(111);
    ICellStyle cellStyle5 = workbook.CreateCellStyle();
    cellStyle5.DataFormat = workbook.CreateDataFormat().GetFormat("[DbNum2][$-804]0.00");//不保留小数: [DbNum2][$-804]0
    cell5.CellStyle = cellStyle5;


    //科学计数法
    ICell cell6 = sheet.CreateRow(5).CreateCell(0);
    cell6.SetCellValue(1234.6666);
    ICellStyle cellStyle6 = workbook.CreateCellStyle();
    cellStyle6.DataFormat = HSSFDataFormat.GetBuiltinFormat("0.00E+00");
    cell6.CellStyle = cellStyle6;

    var path = Path.Combine(Directory.GetCurrentDirectory(), "test1.xls");
    using (FileStream file = new FileStream(path, FileMode.Create))
    {
        workbook.Write(file,true);
    }
}

单元格合并

{
    IWorkbook workbook = new HSSFWorkbook();
    ISheet sheet = workbook.CreateSheet("sheet1");


    sheet.AddMergedRegion(new CellRangeAddress(0, 3, 1, 10));//合并单元格,4个参数依次为为startRow,endRow,startCol,endCol
    ICell cell1 = sheet.CreateRow(0).CreateCell(1);
    cell1.SetCellValue("合并区域1");

    sheet.AddMergedRegion(new CellRangeAddress(5, 8, 0, 10));//合并单元格,4个参数依次为为startRow,endRow,startCol,endCol
    ICell cell2 = sheet.CreateRow(5).CreateCell(0);
    cell2.SetCellValue("合并区域2");


    var path = Path.Combine(Directory.GetCurrentDirectory(), "test2.xls");
    using (FileStream file = new FileStream(path, FileMode.Create))
    {
        workbook.Write(file, true);
    }
}

单元格样式

案例1

           HSSFWorkbook workbook = new HSSFWorkbook();
            ISheet sheet = workbook.CreateSheet("sheet1");
            
            //------------------单元格合并
            sheet.AddMergedRegion(new CellRangeAddress(1, 2, 1, 5));//合并单元格,4个参数依次为为startRow,endRow,startCol,endCol
            ICell cell = sheet.CreateRow(1).CreateCell(1);
            cell.SetCellValue("合并的区域");
            cell.Row.HeightInPoints = 40;//行高
            ICellStyle cellstyle = workbook.CreateCellStyle();

            //----------------设置单元格常用风格
            cellstyle.Alignment = HorizontalAlignment.Left;//水平居左,可选Right,Center
            cellstyle.VerticalAlignment = VerticalAlignment.Bottom;//垂直居中,可选Top,Center
            cellstyle.WrapText = true;//自动换行

            cellstyle.Indention = 4;//缩进4个字节
            //cellstyle.Rotation = 90;//字体旋转90度,取值范围是[-90,90]

            //---------------字体,字体大小、颜色
            IFont font = workbook.CreateFont();
            font.FontHeightInPoints = 24;//字号为24,可以用font.FontHeight = 24 * 20;FontHeight的单位是1/20点

            font.FontName = "楷体";//字体
            font.Boldweight = 700;//加粗
            font.Color = HSSFColor.Blue.Index;//字体颜色
            cellstyle.SetFont(font);
            cell.CellStyle = cellstyle;
            using (FileStream file = new FileStream(@"D:/TestFiles/test.xls", FileMode.Create))
            {
                workbook.Write(file);
            }

案例2

       IWorkbook workbook = new HSSFWorkbook();
            ISheet sheet = workbook.CreateSheet("sheet1");

            ICell cell = sheet.CreateRow(1).CreateCell(1);
            cell.SetCellValue("hello");
            ICellStyle cellstyle = workbook.CreateCellStyle();
            //设置宽度,把第2列设成20字节宽;参数1指定列的索引;参数2指定宽度,单位是1/256个字符宽度
            sheet.SetColumnWidth(1, 20 * 256);
            //高度设成40,单位是点;也可以用cell2.Row.Height = 40 * 20;Height的单位是1/20点
            cell.Row.HeightInPoints = 40;
            //右边框设置成点画线
            cellstyle.BorderRight = BorderStyle.MediumDashDot;
            //右边框设成粉色
            cellstyle.RightBorderColor = HSSFColor.Pink.Index;
            //前景色填充模式,实心
            cellstyle.FillPattern = FillPattern.SolidForeground;
            //前景色填充颜色,黄色
            cellstyle.FillForegroundColor = HSSFColor.Yellow.Index;
            //背景色
            //cellstyle2.FillBackgroundColor = HSSFColor.Green.Index;//背景色设成green
            cell.CellStyle = cellstyle;

            using (FileStream file = new FileStream(@"D:/TestFiles/test.xls", FileMode.Create))
            {
                workbook.Write(file);
            }

参考:
https://www.cnblogs.com/wyy1234/p/10039767.html

待验证:
netcore NPOI 导出大数据防止内存溢出(SXSSFWorkbook)
https://blog.csdn.net/xiaoxionglove/article/details/127710272

posted @ 2021-07-17 19:01  .Neterr  阅读(453)  评论(0编辑  收藏  举报