分享一个 ASP.NET Web Api 上传和读取 Excel的方案

简介: 分享一个 ASP.NET Web Api 上传和读取 Excel的方案

许多业务场景下需要处理和分析大量的数据,而 Excel 是业务人员常用的数据表格工具,因此,将 Excel 表格中内容上传并读取到网站,是一个很常见的功能,目前有许多成熟的开源或者商业的第三方库,比如 NPOI,EPPlus,Spire.Office for .NET 等等,今天分享一个使用 Magicodes.IE.Excel 上传和读取 Excel的方案,这是近年来一个比较受欢迎的开源的第三方库,下面我们用一个 Step By Step 例子来感受它的魅力。

  1. 安装 nuget 包

Magicodes.IE.Excel

Magicodes.IE.Core

2.创建一个 DTO 类

using Magicodes.ExporterAndImporter.Core;
namespace ExcelSample.BusinessEntities.Dtos
{
  public partial class ImportDto
  {
    /// <summary>
    /// ID
    /// </summary>
    [ImporterHeader(Name ="ID")]
    public string ItemGuid { get; set; }
    
    /// <summary>
    /// 巡检编号
    /// </summary>
    [ImporterHeader(Name = "巡检编号")]
    public string InspectionNumber { get; set; }
    
    /// <summary>
    /// 详细地址
    /// </summary>
    [ImporterHeader(Name = "详细位置")]
    public string FormattedAddress { get; set; }
    
    /// <summary>
    /// 开始日期
    /// </summary>
    [ImporterHeader(Name = "开始日期")]
    public string BeginDate { get; set; }
    
    /// <summary>
    /// 截止日期
    /// </summary>
    [ImporterHeader(Name = "结束日期")]
    public string EndDate { get; set; }
    
    /// <summary>
    /// 故障描述
    /// </summary>
    [ImporterHeader(Name = "故障描述")]
    public string FaultInfo { get; set; }
    
    /// <summary>
    /// 单位名称
    /// </summary>
    [ImporterHeader(Name = "单位")]
    public string CustomerName { get; set; }
    
    /// <summary>
    /// 维修说明
    /// </summary>
    [ImporterHeader(Name = "维修说明")]
    public string HandleMeasuresOther { get; set; }
  }
}

3.写公共读取 Export 文件内容方法

using Magicodes.ExporterAndImporter.Core;
using Magicodes.ExporterAndImporter.Core.Extension;
using Magicodes.ExporterAndImporter.Core.Models;
using Magicodes.ExporterAndImporter.Excel;
using System.Collections.Generic;
using System.IO;
using System.Threading.Tasks;
namespace ExcelSample.Common
{
  /// <summary>
  /// excel 工具类
  /// </summary>
  public static class ExportHelper
  {
    /// <summary>
    /// 通用导入 excel 文件
    /// </summary>
    /// <param name="filePath">Excel 文件路径</param>
    public static async Task<ImportResult<T>> ImportExcel<T>(string filePath) where T : class, new()
    {
      IImporter importer = new ExcelImporter();
      var result = await importer.Import<T>(filePath);
      return result;
    }
  }
}

4.写上传 Excel 文件的业务方法

public string UploadFile()
{
  HttpFileCollection files = HttpContext.Current.Request.Files;
  if (files == null || files.Count == 0)
  {
    throw new Exception("没有上传文件");
  }
  
  HttpPostedFile file = files[0];
  string fileExt = Path.GetExtension(file.FileName);
  if (fileExt != ".xlsx" && fileExt != ".xls")
  {
    throw new Exception("不是Excel文件");
  }
  
  string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "ExcelImport");
  if (!Directory.Exists(dir))
  {
    Directory.CreateDirectory(dir);
  }
  
  string fileName = Path.GetFileNameWithoutExtension(file.FileName);
  string fileSaveName = string.Format("{0}{1}.xlsx", fileName, DateTime.Now.ToFlowWaterDate()); 
  string fileSavePath = Path.Combine(dir, fileSaveName);
  _logger.Value.Info($"上传文件:[{fileSavePath}]");
  file.SaveAs(fileSavePath);
  return fileSavePath;
}

5.写具体的读取 Excel 文件内容的业务方法

public List<ImportDto> ReadExcel(string filePath)
{
  var importData = ExportHelper.ImportExcel<ImportDto>(filePath).Result;
  var list = importData.Data.ToList();
  if (list.HasData())
  {
    return list;
  }
  return null;
}

6.在控制器中写 API 向外提供上传和读取 Excel 的接口

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Text;
using System.Threading.Tasks;
using System.Web.Http;
using ExcelSample.Contracts.IService;
using ExcelSample.BusinessEntities.Dtos;
namespace ExcelSample.WebAPI.Controllers.V1
{
  [Authorize]
  [RoutePrefix("api/v1/excelSample")]
  public partial class ExcelSampleController : BaseController
  {
    // ......
    
    [HttpPost]
    [Route("uploadExcel")]
    public IHttpActionResult UploadExcel()
    {
      // 1. 上传文件
      string fileUpload = "";
      try
      {
        fileUpload = UploadFile();
      }
      catch (Exception ex)
      {
        _log.Value.Error(ex, "上传文件失败!");
        return BadRequest(ex.Message);
      }
      // 2. 读取数据
      var list = ReadExcel(fileUpload);
      if (list== null || list.Count == 0)
      {
        return BadRequest("文件没有数据或者数据格式不正确!");
      }
      // 3. 更新数据
      // 存储数据到数据库中
      
      return Ok(Success(result));
    }
    
    // ......
  }
}

7.运行项目并在 Postman 中进行测试


相关文章
|
开发框架 前端开发 JavaScript
ASP.NET Web Pages - 教程
ASP.NET Web Pages 是一种用于创建动态网页的开发模式,采用HTML、CSS、JavaScript 和服务器脚本。本教程聚焦于Web Pages,介绍如何使用Razor语法结合服务器端代码与前端技术,以及利用WebMatrix工具进行开发。适合初学者入门ASP.NET。
|
11月前
|
JSON 编解码 API
Go语言网络编程:使用 net/http 构建 RESTful API
本章介绍如何使用 Go 语言的 `net/http` 标准库构建 RESTful API。内容涵盖 RESTful API 的基本概念及规范,包括 GET、POST、PUT 和 DELETE 方法的实现。通过定义用户数据结构和模拟数据库,逐步实现获取用户列表、创建用户、更新用户、删除用户的 HTTP 路由处理函数。同时提供辅助函数用于路径参数解析,并展示如何设置路由器启动服务。最后通过 curl 或 Postman 测试接口功能。章节总结了路由分发、JSON 编解码、方法区分、并发安全管理和路径参数解析等关键点,为更复杂需求推荐第三方框架如 Gin、Echo 和 Chi。
|
11月前
|
自然语言处理 算法 API
阿里云增值税发票识别NET Rest API调用示例
本文介绍了使用NET代码调用阿里云增值税发票识别API的实现方式。通过示例代码,详细展示了如何构造请求、设置签名以及发送HTTP请求的具体步骤。代码中涵盖了请求参数的处理、签名生成逻辑(如HMAC-SHA256算法)以及调用API后的结果处理。此外,还提供了运行结果的截图和参考文档链接,帮助开发者更好地理解和应用该接口。
1349 4
|
运维 网络安全 文件存储
找不到类似 Docker Desktop 的 Web 管理界面?试试这些开源方案
Docker Desktop 是本地容器化开发的利器,但存在无法通过 Web 远程管理、跨平台体验不一致等问题。为此,推荐几款轻量级、可 Web 化管理的 Docker 工具:Portainer 功能全面,适合企业级运维;CasaOS 集成应用商店和 NAS 功能,适合家庭/个人开发环境;Websoft9 提供预集成环境,新手友好。这些工具能有效提升容器管理效率,满足不同场景需求。
1071 3
|
开发框架 数据可视化 .NET
.NET 中管理 Web API 文档的两种方式
.NET 中管理 Web API 文档的两种方式
339 14
|
开发框架 .NET 程序员
驾驭Autofac,ASP.NET WebApi实现依赖注入详细步骤总结
Autofac 是一个轻量级的依赖注入框架,专门为 .NET 应用程序量身定做,它就像是你代码中的 "魔法师",用它来管理对象的生命周期,让你的代码更加模块化、易于测试和维护
681 4
驾驭Autofac,ASP.NET WebApi实现依赖注入详细步骤总结
|
开发框架 .NET PHP
ASP.NET Web Pages - 添加 Razor 代码
ASP.NET Web Pages 使用 Razor 标记添加服务器端代码,支持 C# 和 Visual Basic。Razor 语法简洁易学,类似于 ASP 和 PHP。例如,在网页中加入 `@DateTime.Now` 可以实时显示当前时间。
|
开发框架 .NET API
Windows Forms应用程序中集成一个ASP.NET API服务
Windows Forms应用程序中集成一个ASP.NET API服务
425 9
|
存储 开发框架 .NET
.NET 8 实现无实体库表 API 部署服务
【10月更文挑战第12天】在.NET 8中,可通过以下步骤实现无实体库表的API部署:首先安装.NET 8 SDK及开发工具,并选用轻量级Web API框架如ASP.NET Core;接着创建新项目并设计API,利用内存数据结构模拟数据存储;最后配置项目设置并进行测试与部署。此方法适用于小型项目或临时解决方案,但对于大规模应用仍需考虑持久化存储以确保数据可靠性与可扩展性。
222 3
|
弹性计算 负载均衡 安全
云端问道-Web应用上云经典架构方案教学
本文介绍了企业业务上云的经典架构设计,涵盖用户业务现状及挑战、阿里云业务托管架构设计、方案选型配置及业务初期低门槛使用等内容。通过详细分析现有架构的问题,提出了高可用、安全、可扩展的解决方案,并提供了按量付费的低成本选项,帮助企业在业务初期顺利上云。
443 0