C#使用NPOI保存DataGridView数据到EXCEL文件

        C# DataGridView可以显示各种表格数据,有时需要将结果保存到EXCEL文件中。开源库NPOI支持EXCEL格式文件的读写,可以使用NPOI编写通用的方法,自动将DataGridView控件表格数据保存到EXCEL文件。

具体代码参考如下:

主要引用:

using NPOI.SS.Formula.Functions;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;

保存方法封装: 

#region 数据保存到文件private void SaveDataGrid2FileXlsx(DataGridView dataGrid,string file){if (diagnoseDataMgrs.Count == 0)return;try{IWorkbook wb = new XSSFWorkbook();//NPOI 使用 HSSFWorkbook 类来处理 xls,XSSFWorkbook 类来处理 xlsx,它们都继承接口 IWorkbook,通过 IWorkbook 来统一处理 xls 和 xlsx 格式的文件ISheet sheet = wb.CreateSheet("mydata");IRow row = null;//获取datagridview的列名,其中 i 表示低级列,i从0开始row = sheet.CreateRow(0);for(int k = 0; k < dataGrid.Columns.Count; k++){row.CreateCell(k).SetCellValue(dataGrid.Columns[k].HeaderText.ToString());}for (int rowCount=0; rowCount < dataGrid.Rows.Count;rowCount ++){row = sheet.CreateRow(rowCount+1);for (int k = 0; k < dataGrid.Columns.Count; k++){row.CreateCell(k).SetCellValue(dataGrid.Rows[rowCount].Cells[k].Value.ToString());}}using (FileStream fs = new FileStream(file, FileMode.OpenOrCreate, FileAccess.ReadWrite)){wb.Write(fs); //写入到Excel中}MessageBox.Show("保存成功,文件名:" + file, "提示!", MessageBoxButtons.OK);}catch (Exception ex){MessageBox.Show("保存出错:" + ex.Message, "出错了!", MessageBoxButtons.OK);}}
#endregion

调用示例:

//WinForm窗体添加DataGridView自动生成
private System.Windows.Forms.DataGridView dataGridView1;string file = $"myFile_{DateTime.Now:yyyy_MM_dd_HH_mm_ss}.xlsx";
SaveDataGrid2FileXlsx(dataGridView1,file);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/748691.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux:深入文件系统

一、Inode 我们使用ls -l的时候看到的除了看到文件名&#xff0c;还看到了文件元数据。 [rootlocalhost linux]# ls -l 总用量 12 -rwxr-xr-x. 1 root root 7438 "9月 13 14:56" a.out -rw-r--r--. 1 root root 654 "9月 13 14:56" test.c 每行包含7列&…

【JavaEE初阶系列】——多线程 之 创建线程

目录 &#x1f388;认识Thread类 &#x1f388;Sleep &#x1f388;创建线程 &#x1f6a9;继承Thread&#xff0c;重写run方法 &#x1f6a9;实现Runnable接口&#xff0c;重写run方法 &#x1f6a9;使用匿名内部类创建 Thread 子类对象 &#x1f6a9;使用匿名内部类&…

stm32_f103c8点亮led(01)

步骤 1设置时钟 2初始化GPIO 3设置输入输出 main函数 #include "stm32f10x.h" // Device header #include "Delay.h" int main(void) {RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);//时钟GPIO_InitTypeDef jie_gpio;//初始…

非空约束

oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 非空约束 所谓的非空约束&#xff0c;指的是表中的某一个字段的内容不允许为空。如果要使用非空约束&#xff0c;只需要在每个列的后面利用“NOT NULL”声明即可 -- 删除数…

AK/SK加密认证

一、AK/SK概念 Access Key (AK)&#xff1a;AK是一个全局唯一的字符串标识符&#xff0c;用于标识用户。它类似于用户名&#xff0c;但仅用于身份识别&#xff0c;并不包含任何秘密信息。 Secret Access Key (SK)&#xff1a;SK则是一个高度保密的密钥&#xff0c;类似于密码&…

【Preprocessing数据预处理】之Scaler

在机器学习中&#xff0c;特征缩放是训练模型前数据预处理阶段的一个关键步骤。不同的缩放器被用来规范化或标准化特征。这里简要概述了您提到的几种缩放器&#xff1a; StandardScaler StandardScaler 通过去除均值并缩放至单位方差来标准化特征。这种缩放器假设特征分布是正…

stm32f103c8走马灯(01_1)

利用GPIO_Write(GPIOA,~0x0001);实现走马灯 在结构体中引脚的多个选择可以利用 | 运算实现多选 如jie_gpio.GPIO_PinGPIO_Pin_0 | GPIO_Pin_01 | GPIO_Pin_2&#xff1b; #include "stm32f10x.h" // Device header #include "Del…

请描述一下Spring MVC的工作流程。在Spring MVC中,DispatcherServlet的作用是什么?

请描述一下Spring MVC的工作流程。 Spring MVC 的工作流程是基于请求驱动的&#xff0c;它围绕 Servlet 设计&#xff0c;将请求映射到处理器&#xff0c;处理器处理请求并返回响应。以下是 Spring MVC 的基本工作流程&#xff1a; 发送请求&#xff1a; 客户端&#xff08;例…

ARM 汇编指令 :(一) MOV

目录 一&#xff1a;MOV指令格式 二&#xff1a;MOV指令的示例 一&#xff1a;MOV指令格式 指令是在ARM架构中用于将数据从一个位置或寄存器复制到另一个位置或寄存器的指令。基本语法格式如下&#xff1a; MOV{cond}{S} Rd, Operand2 其中: {cond}是条件码&#xff0c;可…

PFA烧杯透明聚四氟乙烯刻度量杯

PFA烧杯&#xff0c;刻度清晰&#xff0c;耐酸碱&#xff0c;和有机溶剂。

vue+vite根据版本号清空用户浏览器缓存

项目生产环境发布新版本之后&#xff0c;用户可能会因为一些本地缓存的数据不一样而导致页面报错。这时候可以根据版本号去清空用户缓存。 1、在package.json文件中有一个管理版本号属性&#xff1a;version&#xff0c;在每次打包部署之前修改当前版本号。 2、在main.js文件中…

腾讯春招后端一面(八股篇)

前言 前几天在网上发了腾讯面试官问的一些问题&#xff0c;好多小伙伴关注&#xff0c;今天对这些问题写个具体答案&#xff0c;博主好久没看八股了&#xff0c;正好复习一下。 面试手撕了三道算法&#xff0c;这部分之后更&#xff0c;喜欢的小伙伴可以留意一下我的账号。 1…

VUE tinymce editor 配置手册-封装组件

1、vue 配置&#xff1a; init: {language_url: "./tinymce/zh_CN.js", //public目录下language: "zh_CN",height: 500,menubar: false,plugins: "lists image media table paste link searchreplace anchor code preview pagebreak importcss",…

计算机网络面经八股-HTTP1.0和HTTP1.1的区别?

长连接&#xff1a;HTTP 1.1支持长连接&#xff08;Persistent Connection&#xff09;和请求的流水线&#xff08;Pipelining&#xff09;处理&#xff0c;在一个TCP连接上可以传送多个HTTP请求和响应&#xff0c;减少了建立和关闭连接的消耗和延迟&#xff0c;在HTTP1.1中默认…

ElementUI Message 消息提示,多个显示被覆盖的问题

现象截图&#xff1a; 代码&#xff1a;主要是在this.$message 方法外层加上 setTimeout 方法 <script> export default {name: "HelloWorld",props: {msg: String,},methods: {showMessage() {for (let i 0; i < 10; i) {setTimeout(() > {this.$mess…

《荒野大镖客》等优秀的国产游戏能成为国产3a的标杆吗

中国或许不需要3A&#xff0c;但对于一些玩家来说&#xff0c;国产3A更多的是一个梦想&#xff0c;就像动画爱好者期待的优秀国产2D动画一样。 提问者所说的“玩家众多”&#xff0c;其实非核心玩家占比很高。 其中有一些是《王者荣耀》、《和平精英》等轻手游玩家或者国内二次…

【3GPP】【核心网】【5G】NAS连接管理和UE注册管理状态(超详细)

目录 1. NAS连接管理 2.【5G NR】UE注册管理状态 1. NAS连接管理 NAS连接管理包括通过N1接口在UE和AMF之间建立和释放NAS信令连接的功能。NAS信令连接用于实现UE与核心网络之间的NAS信令交换。当UE接入5G网络时,首先与基站建立RRC连接,当RRC连接建立完成后,UE与基站的空口…

JVM垃圾收集器之CMS垃圾收集器和G1垃圾收集器

CMS垃圾收集器 CMS垃圾收集器 CMS GC的英文名为&#xff1a;“Mostly Concurrent Mark and Sweep Garbage Collector” &#xff08;最大-并发-标记-清除-垃圾收集器&#xff09;。 作用范围&#xff1a; 老年代 算法&#xff1a; 并发标记清除算法。 启用参数&#xff1a;-XX…

CMake官方教程7--加入系统反射

1. 加入系统反射 CMakeList.txt cmake_minimum_required(VERSION 3.15)# set the project name and version project(Tutorial VERSION 1.0)# specify the C standard add_library(tutorial_compiler_flags INTERFACE) target_compile_features(tutorial_compiler_flags INTE…

yolov8 分割 模型 网络 模块图

下图是使用yolov8n-seg-p6.yaml imgsz1472 类别数2的情况下训练得到的静态导出的onnx文件使用netron工具可视化的结果 简单标注了yolov8n-seg-p6.yaml配置文件中各层和netron工具可视化的结果的对应关系