欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#利用NPOI操作Excel(單元格設置)

 更新時間:2022年02月21日 12:15:57   作者:出征的企鵝  
這篇文章主要為大家詳細介紹了C#利用NPOI操作Excel實現單元格設置,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C#利用NPOI操作Excel的單元格設置,供大家參考,具體內容如下

一.合并單元格

NOPI支持對單元格進行合并,還有單元格格式設置!

注意:

在進行單元格合并時必須先創(chuàng)建單元格

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);//創(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(); ?
//設置單元格上下左右邊框線 ?
? ? ? ? ? ? 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(); ?
? ? ? ? ? ? } ?*/

? ? ? ? ? ? //創(chuàng)建一個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);//向打開的這個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();
? ? ? ? }

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

注意:

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

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

相關文章

最新評論