C#winform导出DataGridView数据到Excel表

前提:NuGet安装EPPlus,选择合适的能兼容当前.net framwork的版本

主要代码:

csharp 复制代码
private void btn_export_Click(object sender, EventArgs e)
{
     SaveFileDialog saveFileDialog = new SaveFileDialog();
     saveFileDialog.Filter = "Excel Files|*.xlsx|All Files|*.*"; // 设置文件筛选器
     saveFileDialog.Title = "选择保存位置"; // 设置对话框标题
     saveFileDialog.FileName = "data.csv"; // 设置默认文件名

     if (saveFileDialog.ShowDialog() == DialogResult.OK)
     {
         string filePath = saveFileDialog.FileName;
         // 在这里执行保存文件的操作,可以调用之前的导出到Excel的方法
         ExportToExcel(Dgv, filePath);
     }
 }
csharp 复制代码
private void ExportToExcel(DataGridView dataGridView, string filePath)
{
       // 创建一个新的 Excel 包
       using (ExcelPackage excelPackage = new ExcelPackage())
       {
           // 添加一个工作表
           ExcelWorksheet worksheet = excelPackage.Workbook.Worksheets.Add("Sheet1");

           // 将 DataGridView 的列标题复制到工作表的第一行
           for (int i = 0; i < dataGridView.Columns.Count; i++)
           {
               worksheet.Cells[1, i + 1].Value = dataGridView.Columns[i].HeaderText;
           }

           // 将 DataGridView 的数据复制到工作表中
           for (int i = 0; i < dataGridView.Rows.Count; i++)
           {
               for (int j = 0; j < dataGridView.Columns.Count; j++)
               {
                   worksheet.Cells[i + 2, j + 1].Value = dataGridView.Rows[i].Cells[j].Value;
               }
           }

           // 保存 Excel 文件
           FileInfo excelFile = new FileInfo(filePath);
           excelPackage.SaveAs(excelFile);
       }
   }

报错信息
{"Please set the ExcelPackage.LicenseContext property. See https://epplussoftware.com/developers/licenseexception"}

使用的是 EPPlus 5.0.4 或更高版本,因此需要设置 ExcelPackage.LicenseContext 属性来避免许可证错误。(在 应用程序引用了正确的NuGet包,即 EPPlus 的前提下)即:在设置属性之前,先引入 System.ComponentModel 命名空间,然后在窗体的构造函数中设置 ExcelPackage.LicenseContext 属性为 LicenseContext.NonCommercial,即可解决该问题。


原文链接

相关推荐
Dxy123931021619 小时前
Python的正则表达式如何做数据校验
开发语言·python·正则表达式
UP_Continue19 小时前
C++--右值和移动语义
开发语言·c++
222you20 小时前
Java线程的三种创建方式
java·开发语言
云上漫步者20 小时前
深度实战:Rust交叉编译适配OpenHarmony PC——unicode_width完整适配案例
开发语言·后端·rust·harmonyos
漫漫求20 小时前
Java内存模型【JMM】、JVM内存模型
java·开发语言·jvm
田姐姐tmner20 小时前
Python 全面语法指南
开发语言·python
white-persist20 小时前
【攻防世界】reverse | simple-check-100 详细题解 WP
c语言·开发语言·汇编·数据结构·c++·python·算法
wuguan_20 小时前
C#中的静态成员、常量和只读变量
开发语言·c#
秋雨雁南飞20 小时前
C# SignalR 添加Swagger
c#·swagger·signalr
张人玉20 小时前
C# 与西门子 PLC 通信:地址相关核心知识点
开发语言·microsoft·c#·plc