分享一个 ASP.NET Web Api 上传和读取 Excel的方案
代码掌控者 2024-06-29 12:33:01 阅读 69
前言
许多业务场景下需要处理和分析大量的数据,而 Excel 是业务人员常用的数据表格工具,因此,将 Excel 表格中内容上传并读取到网站,是一个很常见的功能,目前有许多成熟的开源或者商业的第三方库,比如 NPOI,EPPlus,Spire.Office for .NET 等等,今天分享一个使用 Magicodes.IE.Excel 上传和读取 Excel的方案,这是近年来一个比较受欢迎的开源的第三方库,下面我们用一个 Step By Step 例子来感受它的魅力。
Step By Step 步骤
安装 nuget 包
Magicodes.IE.Excel
Magicodes.IE.Core
创建一个 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; }
}
}
写公共读取 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;
}
}
}
写上传 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;
}
写具体的读取 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;
}
在控制器中写 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));
}
// ......
}
}
运行项目并在 Postman 中进行测试
总结
Magicodes.IE.Excel 功能不比 NPOI 等其他第三方库逊色,使用也相对比较简单,只需几行代码就可以读取 Excel 文件的内容,不失为一个新的读写 Excel 方案的选择,大家有兴趣可以到 GitHub 下载其源码深入了解。
上一篇: 【waf防火墙】基于nginx+lua实现的waf防火墙搞定web攻击和防刷限流
下一篇: web期末作业设计网页:网站设计——blackpink(5页) HTML+CSS+JavaScript 学生DW网页设计作业成品 网页设计作业 web网页设计与开发 html实训大作业
本文标签
声明
本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。