用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法
今天在做项目中,遇到使用代码生成具有一定样式的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下载.