当前位置: 首页 > news >正文

使用NPOI自定义导出excel文件

说明

1、自定义列名,将从数据库查询到的数据赋值到对应的单元格上。
2、excel文件默认导出到桌面。
3、支持进度条显示。

界面

在这里插入图片描述

功能实现

 public void TaskTest(){Task task = new Task(ExportExcel);task.Start(); }
/// <summary>/// 查询数据/// </summary>/// <returns></returns>public DataTable GetResource(){using (MySqlConnection conn=new MySqlConnection(mysqlConn)){conn.Open();string sql = string.Format(@"select device_level,device_id,device_name,bay_id,bay_name,main_device_id,main_device_name from MasterDevices LIMIT 0,100");DataTable dt = MySqlHelper.ExecuteDataset(conn, sql).Tables[0];return dt;}}
 /// <summary>/// 导出excel/// </summary>public void ExportExcel(){//1:代码创建一个Excel表格(这里称为工作簿)//创建Excel文件的对象 工作簿(调用NPOI文件)HSSFWorkbook excelBook = new HSSFWorkbook();ICellStyle style = excelBook.CreateCellStyle();//创建Excel工作表ISheet sheet = excelBook.CreateSheet("测试表");//创建行对象,填充表头IRow row = sheet.CreateRow(0);//获取数据源DataTable dt = GetResource();//设置进度条progressBar.Maximum = dt.Rows.Count;foreach (DataColumn column in dt.Columns){row.CreateCell(0).SetCellValue("级别");row.CreateCell(1).SetCellValue("设备点位编号");row.CreateCell(2).SetCellValue("设备点位名称");row.CreateCell(3).SetCellValue("间隔编号");row.CreateCell(4).SetCellValue("间隔名称");row.CreateCell(5).SetCellValue("主设备编号");row.CreateCell(6).SetCellValue("主设备名称");}//填充内容for (int i = 0; i < dt.Rows.Count; i++){//设置进度条的值progressBar.Value = i+1;row = sheet.CreateRow(i + 1);for (int j = 1; j <= dt.Columns.Count; j++){row.CreateCell(j - 1).SetCellValue(dt.Rows[i][j-1].ToString());sheet.AutoSizeColumn(j);}}//写入文件string DesktopPath = Environment.GetFolderPath(Environment.SpecialFolder.DesktopDirectory);FileStream xlsfile = new FileStream(DesktopPath + @"\测试Excel" + DateTime.Now.ToString("yyyy-MM-dd") + ".xls", FileMode.Create);excelBook.Write(xlsfile);xlsfile.Close();MessageBox.Show("Excel文件已导出到桌面", "提示");}

具体效果

在这里插入图片描述
在这里插入图片描述

http://www.lryc.cn/news/534955.html

相关文章:

  • 基于vue2 的 vueDraggable 示例,包括组件区、组件放置区、组件参数设置区 在同一个文件中实现
  • 使用rknn进行facenet部署
  • #渗透测试#批量漏洞挖掘#29网课交单平台 SQL注入
  • 百问网imx6ullpro调试记录(linux+qt)
  • 【python】3_容器
  • 数据结构与算法:动态规划dp:背包问题:理论基础(状态压缩/滚动数组)和相关力扣题(416. 分割等和子集、1049.最后一块石头的重量Ⅱ、494.目标和)
  • 数字游牧时代:IT人力外包的范式革命与文明重构
  • Qt - 地图相关 —— 3、Qt调用高德在线地图功能示例(附源码)
  • cloudberry测试
  • RocketMQ、RabbitMQ、Kafka 的底层实现、功能异同、应用场景及技术选型分析
  • UWB功耗大数据插桩调研
  • 郭羽冲IOI2024参赛总结
  • 03:Spring之Web
  • lx-music落雪音乐-开源免费听歌软件[提供最新音源使用, 支持全网平台, 支持无损音乐下载]
  • 129,【2】buuctf [BJDCTF2020]EzPHP
  • Python 面向对象(类,对象,方法,属性,魔术方法)
  • C语言之扫雷
  • 半导体制造工艺讲解
  • Ollama+DeepSeek R1+AnythingLLM训练自己的AI智能助手
  • 基于java手机销售网站设计和实现(LW+源码+讲解)
  • 5-R循环
  • Qlabel 每五个一换行 并、号分割
  • 加速PyTorch模型训练:自动混合精度(AMP)
  • 【py】python安装教程(Windows系统,python3.13.2版本为例)
  • Django REST Framework:如何获取序列化后的ID
  • QT修仙笔记 事件大圆满 闹钟大成
  • Leetcode - 149双周赛
  • 解决 ComfyUI-Impact-Pack 中缺少 UltralyticsDetectorProvider 节点的问题
  • 使用Kickstart配置文件封装操作系统实现Linux的自动化安装
  • Android笔记【snippet】