網站首頁 編程語言 正文
本文實例為大家分享了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(); ? ? ? ? }
這是兩部分代碼,由注釋分開了,再測試的時候進行自己調整!
注意:
單元格在進行合并時,會默認保存左上角的值!
原文鏈接:https://blog.csdn.net/zjw1604080128/article/details/83044540
相關推薦
- 2022-07-03 Qt讀寫ini文件之QSettings用法_C 語言
- 2022-12-27 Go學習筆記之map的聲明和初始化_Golang
- 2022-03-26 asp.net?core?中優雅的進行響應包裝的實現方法_實用技巧
- 2022-07-01 Python自動操作Excel文件的方法詳解_python
- 2022-06-15 golang?Gin上傳文件返回前端及中間件實現示例_Golang
- 2021-12-16 linux下wget命令的基本使用方法_Linux
- 2022-07-28 C++中操作符的前置與后置有什么區別_C 語言
- 2022-04-19 css塊級元素,行內元素和行內塊級元素
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支