.NET修仙传
修炼秘籍
.net 修炼路线图
书籍大全
C#入门后该如何进阶?如何提升自己?
读写 Excel 四种方案
书籍大全
dotnet命令大全
C# 程序集加载方法
linux 下部署.net环境
.NET WebAPI中FromRoute、FromQuery、FromBody的关键角色与用法
C# 新用法
盘点C#最有价值的10个语法糖
C#基础语法与数据类型
序列化
C# 7.0
模式匹配Pattern Matching
优秀实用的类库推荐
2024年C#优秀实用的类库推荐
依赖注入与中间件
依赖注入
查询所有已注入的服务
WebApi实现批量注入
原生依赖注入
自动依赖注入框架
优秀中间件
依赖注入
Autofac
生命周期
文档操作
PDF操作
PDF合并及生成书签目录
Excel操作
几个Excel文件合并去重分类
Excel文件之COM组件方式
操作Excel文件之NPOI
INI文件
面试宝典
WebService、WCF、WebAPI、一般处理程序
C# 线程和进程的区别
asp.net core 服务生命周期
asp.net core 的中间件都有哪些
操作系统编程
获取搜狗输入法中英文
com组件集成
执行系统命令
通过句柄嵌入exe窗体程序
windows-开机自启动
程序调用cmd命令生成WCF服务的客户端调用文件
获取电脑信息
键盘记录器
键盘改键功能
监听鼠标操作
框架揭秘
01编程初体验
中间件 Middleware
路由
配置管理
配置系统
配置管理
日志管理
Log4Net
NLog
.net core原始日志记录
日志管理
Serilog
LINQ
LINQ概讲
LINQ编程
常用方法
ORM
EF Core初始化
EF Core的实体类配置
执行原生SQL语句
EF Core
操作sqlite
操作Mysql数据库
操作LiteDB
AutoMapper高效实现对象映射
AutoMapper
AutoMapper 10个常用方法总结
缓存
Redis支持哪几种数据类型?
什么是Redis?简述它的优缺点?
Redis相比memcached有哪些优势?
认证
什么是 JWT?它是如何工作的?
.net framework jwt
.net core Jwt操作
认证管理
.Net WebApi校验Token/参数的几种方式
鉴权授权
Authorization的几种方式
基础语法
集合
1、C#中常用集合类型
yield return 简化迭代并提高代码质量
AOP
.net core AOP
操作筛选器
网络编程
TCP 连接的前世今生
HttpRequest,WebRequest,HttpWebRequest,WebClient,HttpClient 之间的区别
网络编程
WebApi获取客户信息
通信
HTTP通信
公共类-HttpHelper
多线程编程
十种线程方式分析
Task-筑基期
parallel-筑基
消息队列
Kafka、ActiveMQ、RabbitMQ、RocketMQ 有什么优缺点?
构建高性能 API 的高级技术
优秀教程网站
每日学习地址
全套教程汇总
理解ASP.NET Core
定时任务
定时器的三种使用方式
定时任务之windows任务计划程序
创建任务到Windows任务计划程序
定时任务之Quartz.Net
IHostedService启动时运行定时任务
JSON序列化反序列化工具
前辈
发布部署
应用部署
GRPC
使用GRPC多个proto文件
本文档使用 MrDoc 发布
-
+
首页
操作Excel文件之NPOI
# 读取 NPOI、NPOI.OOXML、NPOI.OpenXml4Net、NPOI.OpenXmlFormats using NPOI.HSSF.UserModel; using NPOI.HSSF.Util; using NPOI.SS.UserModel; using NPOI.SS.Util; using NPOI.XSSF.UserModel; using System.IO; ```java //实例化一个datatable用来存储数据 DataTable dt = new DataTable(); //指定excel所在路径 string excelPath = "d:\\1.xlsx"; //以文件流读取excel文件 FileStream fs = new FileStream(excelPath, FileMode.Open, FileAccess.Read); //Offic2007以上 IWorkbook workbook = new XSSFWorkbook(fs); //Offic2007以下 if (excelPath.ToLower().EndsWith(".xls")) { workbook = new HSSFWorkbook(fs); } //取第一个sheet页的数据 ISheet sheet = workbook.GetSheetAt(0); //获取第一行数据 IRow firstRow = sheet.GetRow(0); //获取第一行中数据列的数量 int columnCount = firstRow.LastCellNum; for (int i = firstRow.FirstCellNum; i <= columnCount; i++) { //获取单元格 ICell cell = firstRow.GetCell(i); if (cell != null) { //将第一行数据作为表头 string cellValue = cell.StringCellValue; if (!string.IsNullOrEmpty(cellValue)) { dt.Columns.Add(cellValue); } } } //获取数据行的数量 int rowCount = sheet.LastRowNum; for (int i = 1; i <= rowCount; i++) { //获取行 IRow row = sheet.GetRow(i); if (row == null) continue; DataRow dataRow = dt.NewRow(); for (int j = row.FirstCellNum; j <= dt.Columns.Count; j++) { if (row.GetCell(j) != null) { //这里减FirstCellNum可以去除空白列数据 dataRow[j - row.FirstCellNum] = row.GetCell(j).ToString(); } } dt.Rows.Add(dataRow); } //资源释放 workbook.Close(); //显示到页面 dataGridView1.DataSource = dt; ``` # 写入 ```java DataTable dt = dataGridView1.DataSource as DataTable; //指定excel所在路径 string excelPath = "d:\\2.xlsx"; //以文件流创建excel文件 FileStream fs = new FileStream(excelPath, FileMode.OpenOrCreate, FileAccess.ReadWrite); //Offic2007以上 IWorkbook workbook = new XSSFWorkbook(); //Offic2007以下 if (excelPath.ToLower().EndsWith(".xls")) { workbook = new HSSFWorkbook(); } //创建一个sheet页 ISheet sheet = workbook.CreateSheet("sheet1"); //创建第一行数据并将表头写进去 IRow rowHead = sheet.CreateRow(0); for (int j = 0; j < dt.Columns.Count; j++) { rowHead.CreateCell(j).SetCellValue(dt.Columns[j].ColumnName); } //将数据逐行写入 for (int i = 0; i < dt.Rows.Count; i++) { IRow row = sheet.CreateRow(i + 1); for (int j = 0; j < dt.Columns.Count; j++) { row.CreateCell(j).SetCellValue(Convert.ToString(dt.Rows[i][j])); } } workbook.Write(fs); //资源释放 workbook.Close(); ``` # 样式 ```java DataTable dt = dataGridView1.DataSource as DataTable; //指定excel所在路径 string excelPath = "d:\\2.xlsx"; //以文件流创建excel文件 FileStream fs = new FileStream(excelPath, FileMode.OpenOrCreate, FileAccess.ReadWrite); //Offic2007以上 IWorkbook workbook = new XSSFWorkbook(); //Offic2007以下 if (excelPath.ToLower().EndsWith(".xls")) { workbook = new HSSFWorkbook(); } //创建一个sheet页 ISheet sheet = workbook.CreateSheet("sheet1"); //创建第一行数据并将表头写进去 IRow rowHead = sheet.CreateRow(0); for (int j = 0; j < dt.Columns.Count; j++) { rowHead.CreateCell(j).SetCellValue(dt.Columns[j].ColumnName); } //将数据逐行写入 for (int i = 0; i < dt.Rows.Count; i++) { IRow row = sheet.CreateRow(i + 1); for (int j = 0; j < dt.Columns.Count; j++) { row.CreateCell(j).SetCellValue(Convert.ToString(dt.Rows[i][j])); } } //创建样式 ICellStyle style = workbook.CreateCellStyle(); //设置单元格居中 style.Alignment = NPOI.SS.UserModel.HorizontalAlignment.Center; style.VerticalAlignment = NPOI.SS.UserModel.VerticalAlignment.Center; //新建一个字体样式对象 IFont font = workbook.CreateFont(); //设置字体大小 font.FontHeightInPoints = 14; //设置字体加粗 font.IsBold = true; //设置字体颜色 font.Color = HSSFColor.Red.Index; style.SetFont(font); //设置行的高度 rowHead.Height = 800; //设置列的宽度 sheet.SetColumnWidth(0, 5000); //设置单元格样式 rowHead.GetCell(2).CellStyle = style; //设置单元格合并 //CellRangeAddress参数分别为:起始行,结束行,起始列,结束列 //索引从0开始 sheet.AddMergedRegion(new CellRangeAddress(4, 5, 0, 2)); //设置单元格公式 ICell cell2 = sheet.CreateRow(dt.Rows.Count + 1).CreateCell(2); cell2.CellFormula = "C2+C3"; /*以下代码可判断单元格格式是否为公式 if (rowHead.GetCell(1).CellType == CellType.Formula) { //判断单元格值是什么类型 if (HSSFDateUtil.IsCellDateFormatted(rowHead.GetCell(1))) { } } */ //读取图片转为byte Image img = Image.FromFile("d:\\c.png"); MemoryStream ms = new MemoryStream(); img.Save(ms, ImageFormat.Png); byte[] b = ms.ToArray(); int picIndex=workbook.AddPicture(b, PictureType.PNG); IDrawing patriarch = sheet.CreateDrawingPatriarch(); //在第9行第5列插入大小为 高8行宽6列的图片(索引从0开始) XSSFClientAnchor anchor = new XSSFClientAnchor { Row1 = 8, Row2 = 16, Col1 = 4, Col2 = 10 }; patriarch.CreatePicture(anchor, picIndex); workbook.Write(fs); fs.Close(); workbook.Close(); ``` 
孙端己
2024年9月30日 11:46
转发文档
收藏文档
上一篇
下一篇
手机扫码
复制链接
手机扫一扫转发分享
复制链接
Markdown文件
分享
链接
类型
密码
更新密码