用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();

时间: 2024-10-12 16:27:47

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

NPOI之Excel——合并单元格、设置样式、输入公式

首先建立一个空白的工作簿用作测试,并在其中建立空白工作表,在表中建立空白行,在行中建立单元格,并填入内容: //建立空白工作簿 IWorkbook workbook = new HSSFWorkbook(); //在工作簿中:建立空白工作表 ISheet sheet = workbook.CreateSheet(); //在工作表中:建立行,参数为行号,从0计 IRow row = sheet.CreateRow(0); //在行中:建立单元格,参数为列号,从0计 ICell cell = ro

NPOI之Excel——合并单元格、设置样式、输入公式、设置筛选等

首先建立一个空白的工作簿用作测试,并在其中建立空白工作表,在表中建立空白行,在行中建立单元格,并填入内容: //建立空白工作簿 IWorkbook workbook = new HSSFWorkbook(); //在工作簿中:建立空白工作表 ISheet sheet = workbook.CreateSheet(); //在工作表中:建立行,参数为行号,从0计 IRow row = sheet.CreateRow(0); //在行中:建立单元格,参数为列号,从0计 ICell cell = ro

NPOI 创建Excel,数据读取与写入

<1> using System; using System.Collections.Generic; using System.Linq; using System.Web; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.SS.Formula.Functions; using System.IO; using System.Text; namespace 导入导出Excel { /// <summary&g

NPOI导出Excel合并表头写入公式

protected void Btn1_Click(object sender, EventArgs e) { //建立空白工作簿 IWorkbook workbook = new HSSFWorkbook(); //在工作簿中:建立空白工作表 ISheet sheet = workbook.CreateSheet(); #region //在工作表中:建立行,参数为行号,从0计 IRow row = sheet.CreateRow(0); //在行中:建立单元格,参数为列号,从0计 ICell

NPOI 创建Excel 设置宽度 样式 颜色对比表

前两天用NPOI来操作Office软件,在使用的时候有点问题,也有收获,就做个笔记 记录下来,主要做的事数据的导出功能.一些公共的方法,做个笔记. 更多的详细内容可以到NPOI的官方教程去看  http://tonyqus.sinaapp.com/ 1.引用NPOI 这个,使用第三方类库就要添加DLL ,我使用的是1.2.5的版本 ,具体的版本可以在属相中找到 如下图. 貌似最新的版本到了2.0了 DLL文件点击下载 2.创建简单的一个Excel MemoryStream ms = new Me

excel合并连续相同的单元格

相信很多经常使用excel的同学为了格式美观经常需要把连续相同的单元格(如班级.类型)进行合并. 如果数据量较小,手工点击合并即可.但如果是大量的数据,如几千行.那可真是麻烦! 所以,作者在一次遇到较多单元格的时候变写了一段vba来实现. 初次写是为了合并连续相同的行,后来了解到有些同事也需要,而且有时候是针对列来合并,所以又编辑了一下,可以自动识别行或列. 一个小例子: 先选中第一列有文字部分,然后点击:[我是做成了一个加载项,比较方便] 再选中第一行有文字部分,然后点击该宏.得到如下结果:

NPOI 生成Excel (单元格合并、设置单元格样式:字段,颜色、设置单元格为下拉框并限制输入值、设置单元格只能输入数字等)

NPIO源码地址:https://github.com/tonyqus/npoi NPIO使用参考:源码中的 NPOITest项目 下面代码包括: 1.包含多个Sheet的Excel 2.单元格合并 3.设置单元格样式:字段,颜色 4.设置单元格为下拉框并限制输入值 5.设置单元格只能输入数字 // // GET: /Excel/ public ActionResult Write() { var workbook = new HSSFWorkbook();//从流内容创建Workbook对象

使用openpyxl创建excel并设置单元格样式

wb = Workbook() ws = wb.create_sheet('月度排名汇总', 0) # 合并单元格 ws.merge_cells('b2:b3') ws.merge_cells('c2:c3') ws.merge_cells('d2:d3') ws.merge_cells('e2:g2') ws.merge_cells('h2:j2') # 设置单元格文本内容 ws['b2'].value = '负责人' ws['c2'].value = '部门/小组' ws['d2'].val

NPOI_winfrom导出Excel表格(合并单元格、规定范围加外边框、存储路径弹框选择)

1.导出 1 private void btn_print_Click(object sender, EventArgs e) 2 { 3 DataTable dtNew = new DataTable(); 4 5 dtNew.Columns.Add(new DataColumn("commodity_name", typeof(object))); 6 dtNew.Columns.Add(new DataColumn("specifications", type