分享一个 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 中进行测试


相关文章
|
5月前
|
缓存 监控 供应链
亚马逊 MWS API 实战:商品详情精准获取与跨境电商数据整合方案
本文详细解析亚马逊MWS API接口的技术实现,重点解决跨境商品数据获取中的核心问题。文章首先介绍MWS接口体系的特点,包括多站点数据获取、AWS签名认证等关键环节,并对比普通电商接口的差异。随后深入拆解API调用全流程,提供签名工具类、多站点客户端等可复用代码。针对跨境业务场景,文章还给出数据整合工具实现方案,支持缓存、批量处理等功能。最后通过实战示例展示多站点商品对比和批量选品分析的应用,并附常见问题解决方案。该技术方案可直接应用于跨境选品、价格监控等业务场景,帮助开发者高效获取亚马逊商品数据。
监控 安全 API
392 0
|
5月前
|
人工智能 安全 API
API安全厂商F5首发后量子加密方案,为企业后量子时代加固防线
API安全厂商F5首发后量子加密方案,为企业后量子时代加固防线
151 1
|
5月前
|
供应链 数据可视化 BI
多平台数据整合工具新趋势:支持API实时联动的看板方案
在电商运营中,数据分散在多个平台导致效率低下、决策滞后。数据整合看板工具通过聚合多源数据,实现可视化、实时同步与低门槛操作,帮助团队高效利用数据,提升运营效率与决策质量。
|
6月前
|
JSON 缓存 API
孔夫子旧书网 API 实战:古籍与二手书数据获取及接口调用方案
孔夫子旧书网作为国内知名古籍与二手书交易平台,其数据对图书收藏、学术研究及电商系统具有重要价值。本文详解其API调用方法,涵盖认证机制、搜索参数、数据解析及反爬策略,并提供可直接使用的Python代码,助力开发者合规获取数据。
|
6月前
|
XML 缓存 API
eBay 商品详情 API 深度解析:从基础信息到变体数据获取全方案
本文详解如何通过 eBay 的 GetItem 和 GetMultipleItems 接口获取商品详情数据,涵盖基础属性、价格、变体、卖家信息等,并提供可复用的 Python 代码。内容包括 API 核心参数、响应结构、代码实现、实战注意事项及扩展方向,助力跨境电商开发。
|
6月前
|
前端开发 Java API
利用 Spring WebFlux 技术打造高效非阻塞 API 的完整开发方案与实践技巧
本文介绍了如何使用Spring WebFlux构建高效、可扩展的非阻塞API,涵盖响应式编程核心概念、技术方案设计及具体实现示例,适用于高并发场景下的API开发。
518 0
|
7月前
|
缓存 算法 API
从 0 实现 API 接口签名验证系统:基于 HMAC-SHA256 的防篡改方案(附 Python 全代码)
本文介绍基于 的 API 接口签名验证系统,实现防篡改与防重放攻击,包含完整设计原理、签名生成规则及可运行的 Python 客户端与服务端代码,并提供安全性优化与部署建议。
|
7月前
|
负载均衡 监控 测试技术
【干货满满】高性能API调用方案:如何突破频率限制+异步请求优化
在电商 API 开发中,频率限制常成性能瓶颈。本文提出一套高性能方案,结合异步请求、批量处理、智能限流等技术,显著提升调用效率,突破平台限制,实现稳定高效的数据交互。
|
7月前
|
人工智能 供应链 监控
苏宁易购电商 API 接口,家电库存管理智能方案
苏宁易购推出基于API的智能家电库存管理方案,融合实时数据同步、AI预测与自动化执行,助力企业优化库存周转、降低成本,提升运营效率与客户满意度。适用于ERP/WMS系统集成,实现库存管理智能化升级。
150 0