EPPlus 读取和生成Excel

在项目中添加了EPPlus库的引用,你可以通过NuGet包管理器或手动将EPPlus库添加到项目中。同时,需要注意的是EPPlus库支持的是xlsx格式的Excel文件。

读取

使用EPPlus读取本地Excel文件的示例代码如下:

csharp 复制代码
using OfficeOpenXml;

public void ReadExcel()
{
    // 读取文件路径
    string filePath = "path_to_your_excel_file.xlsx";

    // 创建一个新的ExcelPackage对象
    using (ExcelPackage package = new ExcelPackage(new FileInfo(filePath)))
    {
        // 获取第一个工作表
        ExcelWorksheet worksheet = package.Workbook.Worksheets[0];

        // 获取Excel中的行数和列数
        int rowCount = worksheet.Dimension.Rows;
        int columnCount = worksheet.Dimension.Columns;

        // 遍历每一行
        for (int row = 1; row <= rowCount; row++)
        {
            // 遍历每一列
            for (int col = 1; col <= columnCount; col++)
            {
                // 通过索引获取单元格值
                var cellValue = worksheet.Cells[row, col].Value;
                
                // 在这里进行进一步的处理,比如将数据存储到集合中
                // ...
            }
        }
    }
}

请注意替换代码中的"path_to_your_excel_file.xlsx"为你的本地Excel文件的路径。这个示例代码打开一个Excel文件,读取第一个工作表的所有单元格,并对每个单元格的值进行处理。你可以根据自己的需求在遍历过程中进行相应的操作,比如将数据存储到集合中。

生成

下面是一个示例代码,演示如何在.NET Core中使用EPPlus生成Excel并通过接口返回给前端:

csharp 复制代码
using OfficeOpenXml;
using System.IO;
using Microsoft.AspNetCore.Mvc;

[ApiController]
[Route("api/[controller]")]
public class ExcelController : ControllerBase
{
    [HttpGet]
    public IActionResult GenerateExcel()
    {
        // 创建一个新的ExcelPackage对象
        using (ExcelPackage package = new ExcelPackage())
        {
            // 添加工作表
            ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("Sheet1");

            // 设置数据到工作表中
            worksheet.Cells["A1"].Value = "Name";
            worksheet.Cells["B1"].Value = "Age";

            worksheet.Cells["A2"].Value = "John";
            worksheet.Cells["B2"].Value = 25;

            worksheet.Cells["A3"].Value = "Jane";
            worksheet.Cells["B3"].Value = 30;

            // 保存Excel文件流
            MemoryStream memoryStream = new MemoryStream();
            package.SaveAs(memoryStream);

            // 设置文件名
            string fileName = "sample.xlsx";

            // 返回Excel文件
            return File(memoryStream.ToArray(), "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", fileName);
        }
    }
}

在这个示例中,我们创建了一个ExcelController控制器,并在其中定义了一个GenerateExcel动作。这个动作使用EPPlus生成Excel文件,将文件保存到MemoryStream中,并使用File方法将MemoryStream作为响应返回给前端。

需要注意的是,你需要确保在控制器中引入了Microsoft.AspNetCore.Mvc命名空间。

通过调用api/Excel接口,你可以获取到生成的Excel文件,并在前端进行下载。

合并单元格

生成Excel文件之前执行了单元格合并操作:

csharp 复制代码
using OfficeOpenXml;
using System.IO;
using Microsoft.AspNetCore.Mvc;

[ApiController]
[Route("api/[controller]")]
public class ExcelController : ControllerBase
{
    [HttpGet]
    public IActionResult GenerateExcel()
    {
        // 创建一个新的ExcelPackage对象
        using (ExcelPackage package = new ExcelPackage())
        {
            // 添加工作表
            ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("Sheet1");

            // 设置数据到工作表中
            worksheet.Cells["A1"].Value = "Name";
            worksheet.Cells["B1"].Value = "Age";

            worksheet.Cells["A2"].Value = "John";
            worksheet.Cells["B2"].Value = 25;

            worksheet.Cells["A3"].Value = "Jane";
            worksheet.Cells["B3"].Value = 30;

            // 合并单元格
            worksheet.Cells["A1:B1"].Merge = true;

            // 保存Excel文件流
            MemoryStream memoryStream = new MemoryStream();
            package.SaveAs(memoryStream);

            // 设置文件名
            string fileName = "sample.xlsx";

            // 返回Excel文件
            return File(memoryStream.ToArray(), "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", fileName);
        }
    }
}

在上述示例中,我们在设置数据之后,通过将Merge属性设置为true,以实现单元格"A1"和"B1"的合并。这将把"A1"和"B1"单元格合并为一个单元格。

相关推荐
小码编匠8 小时前
WPF 中的高级交互通过右键拖动实现图像灵活缩放
后端·c#·.net
唐青枫15 小时前
C#.NET 定时任务与队列利器:Hangfire 完整教程
c#·.net
hez201021 小时前
Runtime Async - 步入高性能异步时代
c#·.net·.net core·clr
葡萄城技术团队1 天前
从100秒到10秒的性能优化,你真的掌握 Excel 的使用技巧了吗?
excel
mudtools1 天前
.NET驾驭Word之力:玩转文本与格式
c#·.net
唐青枫2 天前
C#.NET 数据库开发提速秘籍:SqlSugar 实战详解
c#·.net
mudtools2 天前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
c#·.net
大飞pkz3 天前
【设计模式】C#反射实现抽象工厂模式
设计模式·c#·抽象工厂模式·c#反射·c#反射实现抽象工厂模式
QQ3596773453 天前
ArcGIS Pro实现基于 Excel 表格批量创建标准地理数据库(GDB)——高效数据库建库解决方案
数据库·arcgis·excel
唐青枫3 天前
从入门到进阶:C#.NET Stopwatch 计时与性能测量全攻略
c#·.net