c# npoi操作excel
- 今天在弄使用npoi对excel表的操作,遇到个问题就是使用workbook通过filestream打开后,让后workbook.write(filestream)居然报文件流关闭了,无法写入,弄了好久都不行,最后通过写2个excel文件来解决,现在看来我使用 HSSFWorkbook workbook = new HSSFWorkbook(new FileStream(filePath, FileMode.Open, FileAccess.ReadWrite));这种读写模式有问题,使用这种 using (var stream = new FileStream(filePath, FileMode.Open, FileAccess.Read));既可以读,又可以写。
public void AppendDataToExistingExcel(string filePath)
{
try
{
IWorkbook workbook;
using (var stream = new FileStream(filePath, FileMode.Open, FileAccess.Read))
{
workbook = filePath.EndsWith(".xlsx") ? (IWorkbook)new XSSFWorkbook(stream) : new HSSFWorkbook(stream);
}
var sheet = workbook.GetSheetAt(0);
int lastRowNum = sheet.LastRowNum;
sheet.GetRow(0).CreateCell(0).SetCellValue("hahaha");
using (var stream = new FileStream(filePath, FileMode.Open, FileAccess.Write))
{
workbook.Write(stream);
}
}
catch (Exception ex) {}
}
- Npoi的操作
New一个workbook,workbook通过createSheet()或者getSheetAt(index)获取sheet页面
sheet通过createRow(rowIndex)或者getRow(indexIndex),获取或者创建行
Sheet.lastRownum可以获取所有行
IRow row = sheet.createRow(rowIndex);获取行
Row.capacity 或者row.cells.count获取每一行的列个数,注意的是没有sheet的列个数,只有行的列个数
当向一个行中的一个单元格写数据的时候row.createCell(colIndex),cell.setCellValue(),如果没有向一个单元格写过数据,那么row.getCell()会返回null的
- Cell样式
注意style通过workbook.createStyle(),而不是通过其他获得
有的api有font.isBold =true;但是我这个没有只有通过font.BoldWeight=800来设置,注意是对每一个cell来设置样式 cell.cellStyle= style;也就是for循环行和列来设置样式,
- 合并单元格
只需要new CellRangeAddress()即可,然后sheet.addMergendRegion(cellRangeAddress),这样就合并了,但是合并后,需要写入信息,以及重新设置样式
public class WZExcelUtil
{
/// <summary>
/// 设置一般表格样式
/// </summary>
/// <param name="workbook"></param>
/// <param name="sheetIndex"></param>
public void setNormalCellStyle(IWorkbook workbook, int sheetIndex)
{
ICellStyle style = workbook.CreateCellStyle();
var font = workbook.CreateFont();
font.FontHeightInPoints = 12;
//font.FontName = "Arial";
font.FontName = "仿宋";
style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;
style.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center;
style.SetFont(font);
ISheet sheet = workbook.GetSheetAt(sheetIndex);
int rowNum = sheet.LastRowNum;
for (int rowIndex = 0; rowIndex < rowNum + 1; rowIndex++)
{
IRow row = sheet.GetRow(rowIndex);
//int cols = row.Cells.Capacity;
int cols = row.Cells.Count;
for (int colIndex = 0; colIndex < cols; colIndex++)
{
var cell = sheet.GetRow(rowIndex).GetCell(colIndex);
cell.CellStyle = style;
sheet.SetColumnWidth(colIndex, 15 * 256); // 设置第 1 列宽度为 20
}
row.HeightInPoints = 25; // 设置行高为 25 点
}
}
/// <summary>
/// 设置title表格样式
/// </summary>
/// <param name="workbook"></param>
/// <param name="sheetIndex"></param>
/// <param name="headTitleIndex"></param>
public void setHeadTitleStyle(IWorkbook workbook, int sheetIndex, int headTitleIndex)
{
ISheet sheet = workbook.GetSheetAt(sheetIndex);
ICellStyle style = workbook.CreateCellStyle();
var font = workbook.CreateFont();
font.FontHeightInPoints = 14;
//font.FontName = "Arial";
font.FontName = "仿宋";
font.Boldweight = 800;
style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;
style.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center;
style.SetFont(font);
IRow headRow = sheet.GetRow(headTitleIndex);
int cols = headRow.Cells.Count;
for (int colIndex = 0; colIndex < cols; colIndex++)
{
var cell = headRow.GetCell(colIndex);
cell.CellStyle = style;
}
}
/// <summary>
/// 设置合并单元格
/// </summary>
/// <param name="workbook"></param>
/// <param name="sheetIndex"></param>
/// <param name="picTitleRowIndex"> 内容行索引 </param>
/// <param name="picTitleColIndex"> 内容列索引</param>
/// <param name="titleInfo"> 显示信息</param>
/// <param name="firstRow"></param>
/// <param name="lastRow"></param>
/// <param name="firstCol"></param>
/// <param name="lastCol"></param>
private void setMergeInfo(IWorkbook workbook, int sheetIndex, int picTitleRowIndex, int picTitleColIndex, string titleInfo,
int firstRow, int lastRow, int firstCol, int lastCol)
{
ISheet sheet = workbook.GetSheetAt(sheetIndex);
CellRangeAddress cellRangeAddress = new CellRangeAddress(firstRow, lastRow, firstCol, lastCol);
sheet.AddMergedRegion(cellRangeAddress);
//sheet.GetRow(picTitleRowIndex).GetCell(picTitleColIndex).SetCellValue(titleInfo);
IRow row = sheet.GetRow(picTitleRowIndex);
ICell cell = row.CreateCell(picTitleColIndex); ///getCell(picTitleColIndex);失败,需要create
cell.SetCellValue(titleInfo);
ICellStyle style = workbook.CreateCellStyle();
var font = workbook.CreateFont();
font.FontHeightInPoints = 14;
//font.FontName = "Arial";
font.FontName = "仿宋";
font.Boldweight = 800;
style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center;
style.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center;
style.SetFont(font);
cell.CellStyle = style;
}
private void insertPic(IWorkbook workbook, ISheet sheet,string picpath,int rowleft,int rowright,int colleft,int colright)
{
//string picpath = "C:\\Users\\wangzg\\Desktop\\ceshi.png";
//第一步 获取图片bytes字节
byte[] bytes = File.ReadAllBytes(picpath);
//第二步 确定图片索引,注意图片类型
int ip = workbook.AddPicture(bytes, PictureType.PNG);
//第三步 创建画布
IDrawing drawing = sheet.CreateDrawingPatriarch();
//第三步 创建锚点
IClientAnchor anchor = workbook.GetCreationHelper().CreateClientAnchor();
//第四步 设置锚点左上角 右下角 也就是图片的大小,不过是通过左上点 和右下点来得到的
//anchor.Row1 = 2;
//anchor.Col1 = 1;
//anchor.Row2 = 12;
//anchor.Col2 = 12;
anchor.Row1 = rowleft;
anchor.Col1 = colleft;
anchor.Row2 = rowright;
anchor.Col2 = colright;
//第五步 把图片插入到相应位置
IPicture picture = drawing.CreatePicture(anchor, ip);
}
}
private void button12_Click(object sender, EventArgs e)
{
try
{
string[] headtitle = { "aaaa", "bbb", "ccc", "ddd", "eee" };
List<List<string>> lists = new List<List<string>>();
string target = "C:\\Users\\wangzg\\Desktop\\112_4.xls";
IWorkbook workbook = target.EndsWith(".xlsx") ? (IWorkbook)new XSSFWorkbook() : new HSSFWorkbook();
ISheet sheet = workbook.CreateSheet("taoya");
int headTitleRowIndex = 15;
for (int i = 0; i < 15; i++) {
sheet.CreateRow(i);
}
//表头
IRow headRow = sheet.CreateRow(headTitleRowIndex);
for (int i = 0; i < headtitle.Length; i++)
{
headRow.CreateCell(i).SetCellValue(headtitle[i]);
}
//列值
for (int i = 0; i < 10; i++)
{
List<string> oil = new List<string>();
oil.Add("aa" + i);
oil.Add("bb" + i);
oil.Add("cc" + i);
oil.Add("dd" + i);
oil.Add("ee" + i);
lists.Add(oil);
}
for (int i = 0; i < lists.Count; i++)
{
IRow row = sheet.CreateRow(sheet.LastRowNum + 1);
List<string> objs = lists[i];
for (int j = 0; j < headtitle.Length; j++)
{
row.CreateCell(j).SetCellValue(objs[j]);
}
}
setNormalCellStyle(workbook, 0);
setHeadTitleStyle(workbook, 0, headTitleRowIndex);
setMergeInfo(workbook, 0,1,1, "aaaa");
insertPic(workbook, workbook.GetSheetAt(0));
using (var stream = new FileStream(target, FileMode.Create, FileAccess.Write))
{
workbook.Write(stream);
}
MessageBox.Show("ok");
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
相关文章:
c# npoi操作excel
今天在弄使用npoi对excel表的操作,遇到个问题就是使用workbook通过filestream打开后,让后workbook.write(filestream)居然报文件流关闭了,无法写入,弄了好久都不行,最后通过写2个excel文件来解决,现在看来我…...
十二:HTTP错误响应码:理解与应对
在现代网络技术中,HTTP(超文本传输协议)是浏览器与服务器之间沟通的基础。每当我们访问网站或发送请求,HTTP会返回一个响应码,这些代码不仅可以表示成功,还可以指示各种问题。本文将以HTTP错误响应码为主题,探讨其含义、常见类型及应对措施。 1. 400 Bad Request - 请求…...
Rust学习(六):函数式编程
Rust学习(六):函数式编程 我们在前一篇博客中已经介绍了如何通过trait和impl实现Rust的面向对象编程,但是Rust本身实际上并不提倡通过类来解决问题。Rust推崇的是函数式编程,强调将函数作为参数值或者其他函数的返回值…...

使用 Vue 和 Create-Vue 构建工程化前端项目
目录 前言1. 工程化的意义与 Vue 的生态支持2. 搭建 Vue 工程化项目2.1 环境准备2.2 使用 create-vue 创建项目2.2.1 初始化项目2.2.2 安装依赖2.2.3 本地运行 3. Vue 项目的目录结构解析4. Vue 开发流程详解4.1 项目入口与根组件4.1.1 main.js 的作用4.1.2 App.vue 的结构 4.2…...
opencv图片明暗度判断方法
OpenCV 的LAB 颜色空间(也称为 CIELAB)是一种颜色对手的颜色模型,它旨在模仿人类的色彩感知。LAB 颜色空间由三个分量组成: L: 亮度分量 (Lightness),范围从 0(黑色)到 100(白色&…...

QT6学习第三天
QT6学习第三天 第一个Widgets项目创建项目项目界面简单介绍编译文件介绍 我在第一天中将重点标了颜色,后边我把一些简单的东西都不写了,写了的都是实际用的东西,就不标颜色了。 第一个Widgets项目 首先我们创建一个widgets项目,…...

计算机网络-MSTP基础实验一(单域多实例)
前面我们已经大致了解了MSTP的基本概念和工作原理,但是我自己也觉得MSTP的理论很复杂不结合实验是很难搞懂的,今天来做一个配套的小实验以及一些配置命令。 一、网络拓扑 单域多实例拓扑 基本需求:SW1为VLAN10的网关,SW2为VLAN20的…...
React合成事件及其核心思想详解
相关联Javascript知识 1.JavaScript 的事件流 事件流是 JavaScript 处理事件的机制,它描述了事件从发生到被处理的过程。事件流主要包括两个阶段:捕获阶段和冒泡阶段。在捕获阶段,事件从文档的根元素开始,逐层向下传播到目标元素&…...

Datawhale模型减肥秘籍Tasking之模型量化
Datawhale模型减肥秘籍Tasking之模型量化 什么是量化?为什么量化?量化基本方法基于k-means的量化线性量化 训练后量化量化粒度动态量化参数的计算 ( Cliping )指数移动平均(EMA)Min-MaxKL 量化均方误差(MSE)…...

在云服务器搭建 Docker
操作场景 本文档介绍如何在腾讯云云服务器上搭建和使用 Docker。本文适用于熟悉 Linux 操作系统,刚开始使用腾讯云云服务器的开发者。如需了解更多关于 Docker 相关信息,请参见 Docker 官方。 说明: Windows Subsystem for Linuxÿ…...

Redis 的代理类注入失败,连不上 redis
在测试 redis 是否成功连接时,发现 bean 没有被创建成功,导致报错 根据报错提示,需要我们添加依赖: <dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId>&l…...

版本控制【Git Bash】【Gitee】
目录 一、什么是版本控制? 二、版本控制的种类: 1、本地版本控制 2、集中版本控制 3、分布式版本控制 三、下载Git Bash 四、Git Bash 配置 五、Git Bash使用 1、切换目录:cd 2.查看当前文件路径:pwd 3.列出当前目录下文件…...

Neo4j Desktop 和 Neo4j Community Edition 区别
Neo4j Desktop 和 Neo4j Community Edition 的主要区别在于它们的用途、功能以及安装和管理方式。以下是这两者的详细对比: 1. Neo4j Desktop Neo4j Desktop 是一个图形化的桌面应用程序,主要为开发人员和个人使用提供了一个便捷的环境来安装、管理和运…...

使用uniapp开发微信小程序使用uni_modules导致主包文件过大,无法发布的解决方法
在使用uniapp开发微信小程序时候,过多的引入uni_modules的组件库,会导致主包文件过大,导致无法上传微信小程序,主包要求大小不超过1.5MB.分包大小每个不能超过2M。 解决方法:分包。 1.对每个除了主页面navbar的页面进…...

HarmonyOS NEXT应用元服务开发Intents Kit(意图框架服务)事件推荐开发者测试
意图框架向开发者提供真机测试能力,即开发者可连接设备进行调测。开发者完成代码开发之后,功能正式上架应用市场前,可以在HarmonyOS NEXT设备上面进行自验证,打磨体验。真机测试分为三个步骤:基础信息提供,…...
GD32F103 实践-- MCU编译运行
编译 打开固件库示例工程:在SDK路径下找到固件库示例工程,路径通常是SDK\GD32F10x_Firmware_Library_Template\Keil5_project\Project 选择芯片型号:根据你的MCU型号选择,例如GD32F103RCT6 修改宏定义:根据MCU型号修…...

SQL复杂数据类型处理
背景 数据处理中,经常碰到复杂数据类型,需要将他们进行解析才能利用。 复杂数据类型 1、MAP结构转为列 WITH tmp AS ( SELECT {"Users":{"4418":{"UserId":4418,"Score":0,"IsStudent":true},&q…...

ROS第九梯:ROS+VSCode+Python+C++自定义消息发布和订阅
首先,Python版本的ROS项目和C++版本的ROS项目前期创建功能包的步骤基本一致,具体可参考第二章。 费一步:新建msg文件 在功能包(data_input)目录下创建一个msg文件夹,并在msg文件夹下创建一个名为Box的msg文件,具体如下图所示: 该msg文件为一个用于描述3D Box的文件,…...

【Linux】指令 + 压缩与解压
Linux 一.Linux基本指令1.grep2.zip和unzip1.Linux中的压缩文件发送Windows中2.Linux中接收Windows中压缩文件 3.tar(重要)1.Linux与Linux互传压缩文件 4.bc5.uname 二.Linux相关知识点1.Linux常用热键2.关机操作 一.Linux基本指令 1.grep 行文本过滤工…...

力扣(leetcode)题目总结——动态规划篇
leetcode 经典题分类 链表数组字符串哈希表二分法双指针滑动窗口递归/回溯动态规划二叉树辅助栈 本系列专栏:点击进入 leetcode题目分类 关注走一波 前言:本系列文章初衷是为了按类别整理出力扣(leetcode)最经典题目,…...

黑马Mybatis
Mybatis 表现层:页面展示 业务层:逻辑处理 持久层:持久数据化保存 在这里插入图片描述 Mybatis快速入门 
理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...

渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止
<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet: https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...
Bean 作用域有哪些?如何答出技术深度?
导语: Spring 面试绕不开 Bean 的作用域问题,这是面试官考察候选人对 Spring 框架理解深度的常见方式。本文将围绕“Spring 中的 Bean 作用域”展开,结合典型面试题及实战场景,帮你厘清重点,打破模板式回答,…...

渗透实战PortSwigger靶场:lab13存储型DOM XSS详解
进来是需要留言的,先用做简单的 html 标签测试 发现面的</h1>不见了 数据包中找到了一个loadCommentsWithVulnerableEscapeHtml.js 他是把用户输入的<>进行 html 编码,输入的<>当成字符串处理回显到页面中,看来只是把用户输…...
es6+和css3新增的特性有哪些
一:ECMAScript 新特性(ES6) ES6 (2015) - 革命性更新 1,记住的方法,从一个方法里面用到了哪些技术 1,let /const块级作用域声明2,**默认参数**:函数参数可以设置默认值。3&#x…...
React从基础入门到高级实战:React 实战项目 - 项目五:微前端与模块化架构
React 实战项目:微前端与模块化架构 欢迎来到 React 开发教程专栏 的第 30 篇!在前 29 篇文章中,我们从 React 的基础概念逐步深入到高级技巧,涵盖了组件设计、状态管理、路由配置、性能优化和企业级应用等核心内容。这一次&…...

【java面试】微服务篇
【java面试】微服务篇 一、总体框架二、Springcloud(一)Springcloud五大组件(二)服务注册和发现1、Eureka2、Nacos (三)负载均衡1、Ribbon负载均衡流程2、Ribbon负载均衡策略3、自定义负载均衡策略4、总结 …...
PostgreSQL 与 SQL 基础:为 Fast API 打下数据基础
在构建任何动态、数据驱动的Web API时,一个稳定高效的数据存储方案是不可或缺的。对于使用Python FastAPI的开发者来说,深入理解关系型数据库的工作原理、掌握SQL这门与数据库“对话”的语言,以及学会如何在Python中操作数据库,是…...

【多线程初阶】单例模式 指令重排序问题
文章目录 1.单例模式1)饿汉模式2)懒汉模式①.单线程版本②.多线程版本 2.分析单例模式里的线程安全问题1)饿汉模式2)懒汉模式懒汉模式是如何出现线程安全问题的 3.解决问题进一步优化加锁导致的执行效率优化预防内存可见性问题 4.解决指令重排序问题 1.单例模式 单例模式确保某…...