欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法

程序员文章站 2023-12-18 08:40:46
今天在做项目中,遇到使用代码生成具有一定样式的excel,找了很多资料,最后终于解决了,excel中格式的设置,以及单元格的合并等等。下面就介绍下,使用npoi类库操作ex...

今天在做项目中,遇到使用代码生成具有一定样式的excel,找了很多资料,最后终于解决了,excel中格式的设置,以及单元格的合并等等。下面就介绍下,使用npoi类库操作excel的方法。

  1.首先我们先在内存中生成一个excel文件,代码如下:

    hssfworkbook book = new hssfworkbook();
        isheet sheet = book.createsheet("sheet1");

  2.然后在新创建的sheet里面,创建我们的行和列,代码如下:

复制代码 代码如下:

irow row = sheet.createrow(index);//index代表多少行
row.heightinpoints = 35;//行高
icell cell = row.createcell(0);//创建第一列
cell.setcellvalue(“设置单元格的值”);

  3.设置单元格的样式已经字体大小,边框,以及合并单元格

  (1).创建单元格字体的样式及大小

复制代码 代码如下:

/// <summary>
        /// 获取字体样式
        /// </summary>
        /// <param name="hssfworkbook">excel操作类</param>
        /// <param name="fontname">字体名</param>
        /// <param name="fontcolor">字体颜色</param>
        /// <param name="fontsize">字体大小</param>
        /// <returns></returns>
        public static ifont getfontstyle(hssfworkbook hssfworkbook, string fontfamily, hssfcolor fontcolor, int fontsize)
        {
            ifont font1 = hssfworkbook.createfont();
            if (string.isnullorempty(fontfamily))
            {
                font1.fontname = fontfamily;
            }
            if (fontcolor != null)
            {
                font1.color = fontcolor.getindex();
            }
            font1.isitalic = true;
            font1.fontheightinpoints = (short)fontsize;
            return font1;
        }
  
  (2).设置单元格内显示数据的格式
复制代码 代码如下:

icell cell = row.createcell(1);
icellstyle cellstylenum = excel.geticellstyle(book);
idataformat formatnum = book.createdataformat();
cellstylenum.dataformat = formatnum.getformat("0.00e+00");//设置单元格的格式为科学计数法cell.cellstyle = cellstylenum;

  (3).创建单元格的边框,背景颜色,以及对齐方式
复制代码 代码如下:

/// <summary>
        /// 获取单元格样式
        /// </summary>
        /// <param name="hssfworkbook">excel操作类</param>
        /// <param name="font">单元格字体</param>
        /// <param name="fillforegroundcolor">图案的颜色</param>
        /// <param name="fillpattern">图案样式</param>
        /// <param name="fillbackgroundcolor">单元格背景</param>
        /// <param name="ha">垂直对齐方式</param>
        /// <param name="va">垂直对齐方式</param>
        /// <returns></returns>
        public static icellstyle getcellstyle(hssfworkbook hssfworkbook, ifont font, hssfcolor fillforegroundcolor, fillpatterntype fillpattern, hssfcolor fillbackgroundcolor, horizontalalignment ha, verticalalignment va)
        {
            icellstyle cellstyle = hssfworkbook.createcellstyle();
            cellstyle.fillpattern = fillpattern;
            cellstyle.alignment = ha;
            cellstyle.verticalalignment = va;
            if (fillforegroundcolor != null)
            {
                cellstyle.fillforegroundcolor = fillforegroundcolor.getindex();
            }
            if (fillbackgroundcolor != null)
            {
                cellstyle.fillbackgroundcolor = fillbackgroundcolor.getindex();
            }
            if (font != null)
            {
                cellstyle.setfont(font);
            }
            //有边框
            cellstyle.borderbottom = cellbordertype.thin;
            cellstyle.borderleft = cellbordertype.thin;
            cellstyle.borderright = cellbordertype.thin;
            cellstyle.bordertop = cellbordertype.thin;
            return cellstyle;
        }

  (4).合并单元格 
复制代码 代码如下:

/// <summary>
        /// 合并单元格
        /// </summary>
        /// <param name="sheet">要合并单元格所在的sheet</param>
        /// <param name="rowstart">开始行的索引</param>
        /// <param name="rowend">结束行的索引</param>
        /// <param name="colstart">开始列的索引</param>
        /// <param name="colend">结束列的索引</param>
        public static void setcellrangeaddress(isheet sheet, int rowstart, int rowend, int colstart, int colend)
        {
            cellrangeaddress cellrangeaddress = new cellrangeaddress(rowstart, rowend, colstart, colend);
            sheet.addmergedregion(cellrangeaddress);
        }

  4.将excel文件输出

    filestream stream = file.openwrite(@"f:/test.xls"); ;
            book.write(stream);
            stream.close();

 

  以上就是使用npoi动态生成excel的行和列,以及单元格的样式,具体的可以参考demo下载.

上一篇:

下一篇: