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();
            /*ISheet sheet = wk.CreateSheet("例子");
            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);
ICell MyCell2 = sheet.CreateRow(0).CreateCell(1);

         
           
          
        
MyCell.CellStyle = cellStyle;
//MyCell.SetCellValue("测试格式效果");

            using (FileStream fileStream = File.Open("d:\\pratice3.xlsx",  
            FileMode.OpenOrCreate, FileAccess.ReadWrite))  
            {  
            wk.Write(fileStream);  
            fileStream.Close();  
            }  */

            //创建一个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();
        }

这是两部分代码,由注释分开了,再测试的时候进行自己调整!

注意:
单元格在进行合并时,会默认保存左上角的值!

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在 C# 中使用 NPOI 插入图片到 Excel 单元格中,你可以按照以下步骤操作: 1. 加载 Excel 文件并创建工作簿和工作表对象: ```csharp FileStream fs = new FileStream("test.xlsx", FileMode.Open, FileAccess.ReadWrite); IWorkbook workbook = new XSSFWorkbook(fs); //或者 new HSSFWorkbook(fs) ISheet sheet = workbook.GetSheetAt(0); ``` 2. 创建图片对象并设置其属性: ```csharp byte[] imgBytes = File.ReadAllBytes("image.png"); int pictureIdx = workbook.AddPicture(imgBytes, PictureType.PNG); XSSFDrawing drawing = (XSSFDrawing)sheet.CreateDrawingPatriarch(); XSSFClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, 1, 1, 2, 3); XSSFPicture picture = (XSSFPicture)drawing.CreatePicture(anchor, pictureIdx); ``` 其中,`XSSFDrawing` 和 `XSSFClientAnchor` 是 NPOI 的类,用于设置图片在 Excel 中的位置和大小。`anchor` 的参数依次为:起始列号、起始行号、结束列号、结束行号、起始列偏移量、起始行偏移量、结束列偏移量、结束行偏移量。 3. 将图片插入到单元格中: ```csharp IRow row = sheet.GetRow(0); ICell cell = row.CreateCell(0); cell.SetCellValue("图片插入Excel"); anchor.SetAnchorType(2); picture.Anchor = anchor; ``` 需要注意的是,插入图片的单元格必须为空。如果单元格不为空,可以先将单元格的值清空,再插入图片。 4. 保存 Excel 文件: ```csharp fs.Close(); FileStream outFs = new FileStream("test.xlsx", FileMode.Create); workbook.Write(outFs); outFs.Close(); ``` 这样就可以在 Excel 单元格中插入图片了。需要注意的是,NPOI 只支持插入 PNG 和 JPEG 格式的图片。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值