C#利用NPOI操作Excel(單元格設(shè)置)
本文實(shí)例為大家分享了C#利用NPOI操作Excel的單元格設(shè)置,供大家參考,具體內(nèi)容如下
一.合并單元格
NOPI支持對(duì)單元格進(jìn)行合并,還有單元格格式設(shè)置!
注意:
在進(jìn)行單元格合并時(shí)必須先創(chuàng)建單元格
1.合并單元格語句:
sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, 3)); //起始行,終止行,起始列,終止列
2.設(shè)置單元格格式:
ICellStyle cellStyle = wk.CreateCellStyle(); ?//首先建單元格格式 ? //設(shè)置單元格上下左右邊框線 ? ? ? ? ? ? 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;//細(xì)線 ? //文字水平和垂直對(duì)齊方式 ? cellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Left; ? cellStyle.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Top; ? //是否換行 ? //cellStyle.WrapText = true; ?//若字符串過大換行填入單元格 //縮小字體填充 ? cellStyle.ShrinkToFit = true;//若字符串過大縮小字體后填入單元格 //新建一個(gè)字體樣式對(duì)象 IFont font = wk.CreateFont(); //設(shè)置字體加粗樣式 font.Boldweight = short.MaxValue; ICell MyCell = sheet.CreateRow(1).CreateCell(1);//創(chuàng)建單元格 ? ? ? MyCell.CellStyle = cellStyle;//賦給單元格 ? “剛才所創(chuàng)建的單元格格式”
源碼:
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(); ? //設(shè)置單元格上下左右邊框線 ? ? ? ? ? ? ? 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;//細(xì)線 ? //文字水平和垂直對(duì)齊方式 ? cellStyle.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Left; ? cellStyle.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Top; ? //是否換行 ? //cellStyle.WrapText = true; ?//若字符串過大換行填入單元格 //縮小字體填充 ? cellStyle.ShrinkToFit = true;//若字符串過大縮小字體后填入單元格 //新建一個(gè)字體樣式對(duì)象 IFont font = wk.CreateFont(); //設(shè)置字體加粗樣式 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(); ? ? ? ? ? ? ? } ?*/ ? ? ? ? ? ? //創(chuàng)建一個(gè)Sheet ? ? ? ? ? ? ? ISheet sheet = wk.CreateSheet("例子"); ? ? ? ? ? ? //在第一行創(chuàng)建行 ? ? ? ? ? ? IRow row = sheet.CreateRow(0); ? ? ? ? ? ? //在第一行的第一列創(chuàng)建單元格 ? ? ? ? ? ? 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);//向打開的這個(gè)xls文件中寫入并保存。 ? ? ? ? ? ? } ? ? ? ? ? ? //上一篇教程中生成的文件 ? ? ? ? ? ? ? string Address = "d:\\pratice1.xlsx"; //指明路徑? ? ? ? ? ? ? XSSFWorkbook wk2 = null; ? ? ? ? ? ? using (FileStream fs = File.Open(Address, FileMode.Open, ? ? ? ? ? ? ? FileAccess.Read, FileShare.ReadWrite)) ? ? ? ? ? ? ? { ? ? ? ? ? ? ? //把xlsx文件讀入workbook變量里,之后就可以關(guān)閉了 ? ? ? ? ? ? ? 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(); ? ? ? ? }
這是兩部分代碼,由注釋分開了,再測試的時(shí)候進(jìn)行自己調(diào)整!
注意:
單元格在進(jìn)行合并時(shí),會(huì)默認(rèn)保存左上角的值!
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
winform基于異步委托實(shí)現(xiàn)多線程搖獎(jiǎng)器
這篇文章主要介紹了winform基于異步委托實(shí)現(xiàn)多線程搖獎(jiǎng)器的方法,包含了線程的運(yùn)用及隨機(jī)數(shù)的生成,需要的朋友可以參考下2014-10-10C#使用oledb讀取excel表格內(nèi)容到datatable的方法
這篇文章主要介紹了C#使用oledb讀取excel表格內(nèi)容到datatable的方法,涉及C#操作oledb及datatable的相關(guān)技巧,需要的朋友可以參考下2015-05-05C#中Write()和WriteLine()的區(qū)別分析
這篇文章主要介紹了C#中Write()和WriteLine()的區(qū)別分析,需要的朋友可以參考下2020-11-11c# 免費(fèi)組件html轉(zhuǎn)pdf的實(shí)現(xiàn)過程
這篇文章主要介紹了c# 免費(fèi)組件html轉(zhuǎn)pdf的實(shí)現(xiàn)過程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06C#(.Net)將非托管dll嵌入exe中的實(shí)現(xiàn)
本文主要介紹了C#(.Net)將非托管dll嵌入exe中的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12