这篇“C#中怎么用NPOI操作Excel”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C#中怎么用NPOI操作Excel”文章吧。
一.合并单元格
NOPI支持对单元格进行合并,还有单元格格式设置!
注意:
在进行单元格合并时必须先创建单元格
1.合并单元格语句:
sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, 3));//起始行,终止行,起始列,终止列
2.设置单元格格式:
ICellStyle cellStyle = wk.CreateCellStyle(); //首先建单元格格式 //设置单元格上下左右边框线 cellStyle.BorderTop = NPOI.SS.UserModel.BorderStyle.Hair; //虚线cellStyle.BorderBottom = NPOI.SS.UserModel.BorderStyle.Thick;//粗线 cellStyle.BorderLeft = NPOI.SS.UserModel.BorderStyle.Double;//双线 cellStyle.BorderRight = NPOI.SS.UserModel.BorderStyle.Thin;//细线 //文字水平和垂直对齐方式 cellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Left; cellStyle.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Top; //是否换行 //cellStyle.WrapText = true; //若字符串过大换行填入单元格//缩小字体填充 cellStyle.ShrinkToFit = true;//若字符串过大缩小字体后填入单元格//新建一个字体样式对象IFont font = wk.CreateFont();//设置字体加粗样式font.Boldweight = short.MaxValue;ICell MyCell = sheet.CreateRow(1).CreateCell(1);//创建单元格 MyCell.CellStyle = cellStyle;//赋给单元格 “刚才所创建的单元格格式”
源码:
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.IO;using NPOI;using NPOI.XSSF.UserModel;using NPOI.SS.UserModel;using NPOI.HSSF.UserModel;using NPOI.HSSF.Util;using NPOI.SS.Util;namespace Excel5{ class Program { static void Main(string[] args) { XSSFWorkbook wk = new XSSFWorkbook(); //创建一个Sheet ISheet sheet = wk.CreateSheet("例子"); //在第一行创建行 IRow row = sheet.CreateRow(0); //在第一行的第一列创建单元格 for (int i = 0; i < 10; i++) { ICell cell = row.CreateCell(i); if((i)%4==0) row.CreateCell(i).SetCellValue("测试"); } sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, 3));//起始行,终止行,起始列,终止列 //row.CreateCell(0).SetCellValue("合并单元格"); using (FileStream fs = File.OpenWrite("d:\\pratice1.xlsx")) { wk.Write(fs);//向打开的这个xls文件中写入并保存。 } //上一篇教程中生成的文件 string Address = "d:\\pratice1.xlsx"; //指明路径 XSSFWorkbook wk2 = null; using (FileStream fs = File.Open(Address, FileMode.Open, FileAccess.Read, FileShare.ReadWrite)) { //把xlsx文件读入workbook变量里,之后就可以关闭了 wk2 = new XSSFWorkbook(fs); fs.Close(); } using (FileStream fileStream = File.Open("d:\\pratice1.xlsx", FileMode.OpenOrCreate, FileAccess.ReadWrite)) { wk2.Write(fileStream); fileStream.Close(); } Console.WriteLine("OK"); Console.ReadKey(); }
这是两部分代码,由注释分开了,再测试的时候进行自己调整!
注意:
单元格在进行合并时,会默认保存左上角的值!
以上就是关于“C#中怎么用NPOI操作Excel”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。