ASP.NET Core导入导出Excel文件


希望在ASP.NET Core中导入导出Excel文件,在网上搜了一遍,基本都是使用EPPlus插件,EPPlus挺好用,但商用需要授权,各位码友若有好的工具包推荐,请给我留言,谢谢!

本文利用Asp.net core Razor页面实现Excel文件的导入导出,参考大神的文章:ASP.NET Core 导入导出Excel xlsx 文件 - LineZero - 博客园 (cnblogs.com)

下面为详细步骤。

1,创建Razor项目

2,在Nuget包管理器中搜索EPPlus, 安装依赖包。EPPlus.Core已经弃用,EPPlus是支持Net Core的最新版本。

3,修改pages/Index.cshtml文件,创建基本导入导出页面。

@page
@model IndexModel
@{
ViewData["Title"] = "Home page";
} <div class="text-center">
<h1 class="display-4">ASP.NET Core导入导出Excel文件</h1>
</div> <h2></h2>
<hr />
<div>
<h4>导入Excel</h4>
<hr />
<form enctype="multipart/form-data" method="post" asp-page-handler="Import">
<input type="file" name="excelFile"/>
<input type="submit" value="导入"/>
</form>
<hr /> </div>
<hr />
<div>
<h4>导出Excel</h4>
<form enctype="multipart/form-data" method="post"asp-page-handler="Export">
<input type="submit" value="导出"/>
</form>
</div>
<hr />

4,修改Index.cshtml.cs文件中的代码,增加OnPostImport 和OnPostExport方法,分别用于导入、导出文件。

首先在构造函数中注入webHostEnvironment

        private readonly IWebHostEnvironment _webHostEnvironment;

        public IndexModel(IWebHostEnvironment webHostEnvironment)
{
_webHostEnvironment = webHostEnvironment;
}

OnPostImport代码:

public IActionResult OnPostImport(IFormFile excelFile)
{
ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
string sWebRootFolder = _webHostEnvironment.WebRootPath;
string sFileName = $"{Guid.NewGuid()}.xlsx";
FileInfo file = new FileInfo(Path.Combine(sWebRootFolder, sFileName));
try
{
using (FileStream fs = new FileStream(file.ToString(), FileMode.Create))
{
excelFile.CopyTo(fs);
fs.Flush();
}
using(ExcelPackage package = new ExcelPackage(file))
{
StringBuilder sb = new StringBuilder();
ExcelWorksheet worksheet = package.Workbook.Worksheets[0];
int rowCount = worksheet.Dimension.Rows;
int colCount = worksheet.Dimension.Columns;
bool bheaderRow = true;
for(int row = 1; row <= rowCount; row++)
{
for(int col = 1; col <= colCount; col++)
{
if (bheaderRow)
{
if(worksheet.Cells[row, col].Value != null)
{
sb.Append(worksheet.Cells[row, col].Value.ToString() + "\t");
}
else
{
sb.Append("\t");
}
}
else
{
if(worksheet.Cells[row, col].Value != null)
{
sb.Append(worksheet.Cells[row, col].Value.ToString() + "\t");
}
else
{
sb.Append("\t");
}
}
}
sb.Append(Environment.NewLine);
if (bheaderRow)
{
sb.Append("-----------------------------------------");
sb.Append(Environment.NewLine);
}
bheaderRow = false;
}
return Content(sb.ToString());
}
}
catch(Exception ex)
{
return Content(ex.Message);
}
}

其中必须添加

ExcelPackage.LicenseContext = LicenseContext.NonCommercial 用于指定EPPlus的使用授权为非商用。缺少会报错。

OnPostExport代码:
public IActionResult OnPostExport()
{
string sWebRootFolder = _webHostEnvironment.WebRootPath;
string sFileName = $"{Guid.NewGuid()}.xlsx";
FileInfo file = new FileInfo(Path.Combine(sWebRootFolder, sFileName));
ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
using (ExcelPackage package=new ExcelPackage(file))
{
//add worksheet
ExcelWorksheet workSheet = package.Workbook.Worksheets.Add("AspNetCore");
//add table header
workSheet.Cells[1, 1].Value = "ID";
workSheet.Cells[1, 2].Value = "Name";
workSheet.Cells[1, 3].Value = "Gender";
workSheet.Cells[1, 4].Value = "Age";
workSheet.Cells[1, 5].Value = "Remark"; //Add value
workSheet.Cells["A2"].Value = 1000;
workSheet.Cells["B2"].Value = "张三";
workSheet.Cells["C2"].Value = "男";
workSheet.Cells["D2"].Value = 25;
workSheet.Cells["E2"].Value = "ABCD"; workSheet.Cells["A3"].Value = 1001;
workSheet.Cells["B3"].Value = "李四";
workSheet.Cells["C3"].Value = "女";
workSheet.Cells["D3"].Value = 35;
workSheet.Cells["D3"].Style.Font.Bold = true; workSheet.Cells["A4"].Value = 1003;
workSheet.Cells["B4"].Value = "Amy";
workSheet.Cells["C4"].Value = "Female";
workSheet.Cells["D4"].Value = 22;
workSheet.Cells["E4"].Value = "Hello world"; workSheet.Cells["A5"].Value = 1004;
workSheet.Cells["B5"].Value = "Jim";
workSheet.Cells["C5"].Value = "Male";
workSheet.Cells["D5"].Value = 35;
workSheet.Cells["E5"].Value = 500; package.Save();
} return File(sFileName, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
}

Index.cshtml.cs的完整代码如下:

using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.RazorPages;
using Microsoft.Extensions.Logging;
using OfficeOpenXml;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WebAppTest.Models; namespace WebAppTest.Pages
{
public class IndexModel : PageModel
{
private readonly ILogger<IndexModel> _logger;
private readonly IWebHostEnvironment _webHostEnvironment; public IndexModel(ILogger<IndexModel> logger,IWebHostEnvironment webHostEnvironment)
{
_logger = logger;
_context = context;
_webHostEnvironment = webHostEnvironment;
} public void OnGet()
{ } public IActionResult OnPostImport(IFormFile excelFile)
{
ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
string sWebRootFolder = _webHostEnvironment.WebRootPath;
string sFileName = $"{Guid.NewGuid()}.xlsx";
FileInfo file = new FileInfo(Path.Combine(sWebRootFolder, sFileName));
try
{
using (FileStream fs = new FileStream(file.ToString(), FileMode.Create))
{
excelFile.CopyTo(fs);
fs.Flush();
}
using(ExcelPackage package = new ExcelPackage(file))
{
StringBuilder sb = new StringBuilder();
ExcelWorksheet worksheet = package.Workbook.Worksheets[0];
int rowCount = worksheet.Dimension.Rows;
int colCount = worksheet.Dimension.Columns;
bool bheaderRow = true;
for(int row = 1; row <= rowCount; row++)
{
for(int col = 1; col <= colCount; col++)
{
if (bheaderRow)
{
if(worksheet.Cells[row, col].Value != null)
{
sb.Append(worksheet.Cells[row, col].Value.ToString() + "\t");
}
else
{
sb.Append("\t");
}
}
else
{
if(worksheet.Cells[row, col].Value != null)
{
sb.Append(worksheet.Cells[row, col].Value.ToString() + "\t");
}
else
{
sb.Append("\t");
}
}
}
sb.Append(Environment.NewLine);
if (bheaderRow)
{
sb.Append("-----------------------------------------");
sb.Append(Environment.NewLine);
}
bheaderRow = false;
}
return Content(sb.ToString());
}
}
catch(Exception ex)
{
return Content(ex.Message);
}
} public IActionResult OnPostExport()
{
string sWebRootFolder = _webHostEnvironment.WebRootPath;
string sFileName = $"{Guid.NewGuid()}.xlsx";
FileInfo file = new FileInfo(Path.Combine(sWebRootFolder, sFileName));
ExcelPackage.LicenseContext = LicenseContext.NonCommercial;
using (ExcelPackage package=new ExcelPackage(file))
{
//add worksheet
ExcelWorksheet workSheet = package.Workbook.Worksheets.Add("AspNetCore");
//add table header
workSheet.Cells[1, 1].Value = "ID";
workSheet.Cells[1, 2].Value = "Name";
workSheet.Cells[1, 3].Value = "Gender";
workSheet.Cells[1, 4].Value = "Age";
workSheet.Cells[1, 5].Value = "Remark"; //Add value
workSheet.Cells["A2"].Value = 1000;
workSheet.Cells["B2"].Value = "张三";
workSheet.Cells["C2"].Value = "男";
workSheet.Cells["D2"].Value = 25;
workSheet.Cells["E2"].Value = "ABCD"; workSheet.Cells["A3"].Value = 1001;
workSheet.Cells["B3"].Value = "李四";
workSheet.Cells["C3"].Value = "女";
workSheet.Cells["D3"].Value = 35;
workSheet.Cells["D3"].Style.Font.Bold = true; workSheet.Cells["A4"].Value = 1003;
workSheet.Cells["B4"].Value = "Amy";
workSheet.Cells["C4"].Value = "Female";
workSheet.Cells["D4"].Value = 22;
workSheet.Cells["E4"].Value = "Hello world"; workSheet.Cells["A5"].Value = 1004;
workSheet.Cells["B5"].Value = "Jim";
workSheet.Cells["C5"].Value = "Male";
workSheet.Cells["D5"].Value = 35;
workSheet.Cells["E5"].Value = 500; package.Save();
} return File(sFileName, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
}
}
}

5,运行项目,测试导入导出功能。

导出功能,单击导出按钮,浏览器会下载excel文件,

导入功能,点击选择文件按钮,选择刚下载的excel文件,点击导入按钮,跳转到导入结果页面。


------------------------ 完成---------------------

 

ASP.NET Core导入导出Excel文件的更多相关文章

  1. ASP.NET Core 导入导出Excel xlsx 文件

    ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Li ...

  2. 【转】 (C#)利用Aspose.Cells组件导入导出excel文件

    Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: public static System.Data.DataTable ReadExcel(String strFi ...

  3. (C#)利用Aspose.Cells组件导入导出excel文件

    Aspose.Cells组件可以不依赖excel来导入导出excel文件: 导入: public static System.Data.DataTable ReadExcel(String strFi ...

  4. 导入导出Excel文件

    搭建环境 先新建web project ,然后Add Struts Capabilties: 下载导入导出Excel所需的jar包: poi-3.8-20120326.jar包  :  http:// ...

  5. java中使用poi导入导出excel文件_并自定义日期格式

    Apache POI项目的使命是创造和保持java API操纵各种文件格式基于Office Open XML标准(OOXML)和微软的OLE复合文档格式(OLE2)2.总之,你可以读写Excel文件使 ...

  6. C# 导入导出excel文件案例

    个人总结导出excel报表的案例: //导出报表 protected void btnExport_Click(object sender, EventArgs e) { List<ProOut ...

  7. java导入导出Excel文件

    package poi.excel; import java.io.IOException; import java.io.InputStream; import java.io.OutputStre ...

  8. 简单回顾NPOI导入导出excel文件

    当前环境.net4.0 去官方下下载:  NOPI官网 关于NOPI的详细,这里就不再介绍. 在项目中,我们只需引入  NPOI.dll  就可以了. 接下来..................... ...

  9. SpringMVC 导入导出Excel文件

    /**  * 下载Excel模板 创建一个新的文件用于下载,创建的文件放在缓存中  *   * @param request  * @param response  */ /*  * @Request ...

随机推荐

  1. 在Redis中设置了过期时间的Key,需要注意哪些问题?

    熟悉Redis的同学应该知道,Redis的每个Key都可以设置一个过期时间,当达到过期时间的时候,这个key就会被自动删除. 在为key设置过期时间需要注意的事项 1. DEL/SET/GETSET等 ...

  2. git rebase(变基)操作

    1.rebase(变基)操作 注意事项:rebase 改变分支的根源,绝对不要在与其他人共享的分支上进行操作rebase黄金法则:绝不要在公共的分支上使用它! 1.1git merge 与 git r ...

  3. ARTS第十一周

    受辞职考研和新冠肺炎疫情影响,一直没更.遗憾,数学和专业课再高点就有戏了.继续. 1.Algorithm:每周至少做一个 leetcode 的算法题2.Review:阅读并点评至少一篇英文技术文章3. ...

  4. PyVista:一款Python的三维可视化软件

    技术背景 三维可视化是一项在工业领域中非常重要的技术,而Python中最热门的可视化工具matplotlib和plotly,更加倾向于在数据领域的可视化,用于展现数据的结果.类似的还有百度的pyech ...

  5. HDFS学习总结之架构

    一.hdfs介绍 官网说明 Hadoop Distributed File System (HDFS): A distributed file system that provides high-th ...

  6. springboot-3-web开发

    一.视图层技术thymeleaf 我们一般都是基于3.x版本 1.流程: 导入依赖 <!--整合thymeleaf技术--> <dependency> <groupId& ...

  7. React构建组件的方式

    一.是什么 组件就是把图形.非图形的各种逻辑均抽象为一个统一的概念(组件)来实现开发的模式 在React中,一个类.一个函数都可以视为一个组件 在Vue系列中,我们了解到组件所存在的优势: 降低整个系 ...

  8. Cent OS 7 本地yum源配置与安装

    一.本地yum源 1.添加一个新的yum源配置文件dvd.repo(文件名字自定义)  vi etc/yum.repos.d     添加新的内容: name=rhel_dvd            ...

  9. 【C#】C#中使用GDAL3(一):Windows下超详细编译C#版GDAL3.3.0(VS2015+.NET 4+32位/64位)

    转载请注明原文地址:https://www.cnblogs.com/litou/p/15004877.html 目录 一.介绍 二.编译准备 三.编译SQLite 四.编译LibTiff 五.编译PR ...

  10. transform和tolower

    transform:<algorithm> tolower:<ctype.h> transform有两种使用方法 第一种(参数): 源目标起始迭代器地址 源目标结束迭代器地址 ...