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();
            /*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();
        }

這是兩部分代碼,由註釋分開瞭,再測試的時候進行自己調整!

註意:

單元格在進行合並時,會默認保存左上角的值!

以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。

推薦閱讀: