.Net Core 使用NPOI导入数据
一、搭建环境
1.新建ASP.NET Core Web 应用程序

2.选择API

3.引用Swashbuckle.AspNetCore NuGet 包进行安装. Swashbuckle.AspNetCore 是一个开源项目,用于生成 ASP.NET Core Web API 的 Swagger 文档。
前端开发人员可在浏览器中访问此接口文档。

4.光引用此NuGet包是不行的,还要在Startup中添加并配置Swaage中间件
首先在ConfigureServices中写入以下代码:
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2); #region
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new Info { Title = "API文档", Version = "v1" });
});
#endregion
}
然后在Configure中写入以下代码:
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseHsts();
} #region
app.UseSwagger();
app.UseSwaggerUI(c =>
{
c.SwaggerEndpoint("/swagger/v1/swagger.json", "My API V1");
});
#endregion app.UseHttpsRedirection();
app.UseMvc();
}
5.右键项目生成XML文件,并在Startup中注册服务,用于读取这个XML文档,不然写的接口都不会显示出来.

引用NuGet包:Microsoft.Extensions.PlatformAbstractions

接着在Startup类ConfigureServices方法中,添加如下代码:
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2); #region
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new Info { Title = "API文档", Version = "v1" }); #region
var basePath = PlatformServices.Default.Application.ApplicationBasePath;
//MyImport.xml是我的项目生成XML文档的后缀名,具体的以你项目为主
var xmlPath = Path.Combine(basePath, "MyImport.xml");
c.IncludeXmlComments(xmlPath);
#endregion
});
#endregion
}
OK ,现在可以新建一个控制器,写一个接口看看有没有效果

将地址栏修改一下


我们也可以在launchSettings.json中做一下更改,这样就不用每次都改浏览器地址栏了,如下:

二·、数据库新建表及项目中实体类的建立
--商品表
Create Table Commodity
(
Cid int primary key identity(,),--主键,自增
Name varchar() not null,--商品名称
Price decimal(,) not null,--价格
[Type] varchar() not null,--商品类别
[Time] varchar() not null,--保质期
Remarks varchar()--备注
)
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks; namespace MyImport.Model
{
/// <summary>
/// 商品类
/// </summary>
public class Commodity
{
/// <summary>
/// 主键Id
/// </summary>
[SugarColumn(IsNullable = false, IsPrimaryKey = true, IsIdentity = true)]
public int Cid { get; set; } /// <summary>
/// 商品名称
/// </summary>
[SugarColumn(Length = , IsNullable = false)]
public string Name { get; set; } /// <summary>
/// 商品价格
/// </summary>
[SugarColumn(IsNullable = false)]
public double Price { get; set; } /// <summary>
/// 商品类别
/// </summary>
[SugarColumn(Length = , IsNullable = false)]
public string Type { get; set; } /// <summary>
/// 保质期
/// </summary>
[SugarColumn(Length = , IsNullable = false)]
public string Time { get; set; } /// <summary>
/// 备注
/// </summary>
[SugarColumn(Length = , IsNullable = true)]
public string Remarks { get; set; }
}
}
三、代码编写
注:在写代码之前,先引用两个NuGet包:NPOI(这个包用来操作Excel)和SqlSugarCore(这是一个高性能的ORM框架,操作数据库更便捷)


话不多说,贴代码:
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using MyImport.Model;
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using SqlSugar; namespace MyImport.Controllers
{
[Route("api/[controller]")]
[ApiController]
public class MyCoreController : Controller
{
public MyCoreController()
{ } SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
{
ConnectionString = "Data Source=LENOVO-PC;Initial Catalog=School;Integrated Security=True",
DbType = SqlSugar.DbType.SqlServer,
IsAutoCloseConnection = true
}); /// <summary>
/// 数据导入
/// </summary>
/// <returns></returns>
[HttpPost]
public async Task<string> Import(IFormFile file)
{
string ReturnValue = string.Empty;
//定义一个bool类型的变量用来做验证
bool flag = true;
try
{
string fileExt = Path.GetExtension(file.FileName).ToLower();
//定义一个集合一会儿将数据存储进来,全部一次丢到数据库中保存
var Data = new List<Commodity>();
MemoryStream ms = new MemoryStream();
file.CopyTo(ms);
ms.Seek(, SeekOrigin.Begin);
IWorkbook book;
if (fileExt == ".xlsx")
{
book = new XSSFWorkbook(ms);
}
else if (fileExt == ".xls")
{
book = new HSSFWorkbook(ms);
}
else
{
book = null;
}
ISheet sheet = book.GetSheetAt(); int CountRow = sheet.LastRowNum + ;//获取总行数 if (CountRow - == )
{
return "Excel列表数据项为空!"; }
#region 循环验证
for (int i = ; i < CountRow; i++)
{
//获取第i行的数据
var row = sheet.GetRow(i);
if (row != null)
{
//循环的验证单元格中的数据
for (int j = ; j < ; j++)
{
if (row.GetCell(j) == null || row.GetCell(j).ToString().Trim().Length == )
{
flag = false;
ReturnValue += $"第{i + 1}行,第{j + 1}列数据不能为空。";
}
}
}
}
#endregion
if (flag)
{
for (int i = ; i < CountRow; i++)
{
//实例化实体对象
Commodity commodity = new Commodity();
var row = sheet.GetRow(i); if (row.GetCell() != null && row.GetCell().ToString().Trim().Length > )
{
commodity.Name = row.GetCell().ToString();
}
if (row.GetCell() != null && row.GetCell().ToString().Trim().Length > )
{
commodity.Price = Convert.ToDouble(row.GetCell().ToString());
}
if (row.GetCell() != null && row.GetCell().ToString().Trim().Length > )
{
commodity.Type = row.GetCell().ToString();
}
if (row.GetCell() != null && row.GetCell().ToString().Trim().Length > )
{
commodity.Time = row.GetCell().ToString().ToString();
}
if (row.GetCell() != null && row.GetCell().ToString().Trim().Length > )
{
commodity.Remarks = row.GetCell().ToString();
}
else
{
commodity.Remarks = "暂无";
}
Data.Add(commodity);
}
var data = db.Insertable<Commodity>(Data).ExecuteCommand();
ReturnValue = $"数据导入成功,共导入{CountRow - 1}条数据。";
} if (!flag)
{
ReturnValue = "数据存在问题!" + ReturnValue;
}
}
catch (Exception)
{
return "服务器异常";
} return ReturnValue;
}
}
}
建一个Excel文件,填写好测试数据

打开接口文档,选择这个Excel文件,进行导入

搞定!希望可以帮助到你、^-^

.Net Core 使用NPOI导入数据的更多相关文章
- .Net Core 使用 NPOI 导入Excel
由于之前在网上查阅一些资料发现总是不能编译通过,不能正常使用,现把能正常使用的代码贴出: /// <summary> /// Excel导入帮助类 /// </summary> ...
- .Net core NPOI导入导出Excel
最近在想.net core NPOI 导入导出Excel,一开始感觉挺简单的,后来真的遇到很多坑.所以还是写一篇博客让其他人少走一些弯路,也方便忘记了再重温一遍.好了,多的不说,直接开始吧. 在.Ne ...
- NPOI导入导出Excel数据
代码: using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; using System; usi ...
- .net core利用MySqlBulkLoader大数据批量导入MySQL
最近用core写了一个数据迁移小工具,从SQLServer读取数据,加工后导入MySQL,由于数据量太过庞大,数据表都过百万,常用的dapper已经无法满足.三大数据库都有自己的大数据批量导入数据的方 ...
- .NET Core使用NPOI导出复杂Word详解
前言: 最近使用NPOI做了个导出Word文档的功能,关于使用.NET Core 导出Word文档的方式有很多.最终我为什么选择了NPOI来实现了这个功能,首先是NPOI是一个开源,免费且容易上手的第 ...
- .NET Core使用NPOI导出复杂,美观的Excel详解
前言: 这段时间一直专注于数据报表的开发,当然涉及到相关报表的开发数据导出肯定是一个不可避免的问题啦.客户要求要导出优雅,美观的Excel文档格式的来展示数据,当时的第一想法就是使用NPOI开源库来做 ...
- 搜索引擎Solr系列(二): Solr6.2.1 从MySql中导入数据
一:建立MySql测试表,如下图: 二:solr导入配置: 1.新建demo core文件夹,并修改managed-schema里面的配置文件建立索引字段: 2.把mysql-connector-j ...
- NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中
以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...
- c#.net 使用NPOI导入导出标准Excel (asp.net winform csharp)
尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...
随机推荐
- 四jmeter脚本开发
4.1工作区介绍 4.2http协议录制 a.使用badboy进行录制(目前公司测试系统使用badboy界面不友好,暂时不用,之后再补充) b.jmeter代理服务器进行录制 (1)浏览器代理配置(以 ...
- springboot security+redis+jwt+验证码 登录验证
概述 基于jwt的token认证方案 验证码 框架的搭建,可以自己根据网上搭建,或者看我博客springboot相关的博客,这边就不做介绍了.验证码生成可以利用Java第三方组件,引入 <dep ...
- 深入全面探究有未经处理的异常: 0xC00000FD: Stack overflow(栈溢出)问题!
这两天一直遇到标题上的问题,我相信很多朋友在执行代码的时候都会遇到这样的问题,我在网上也找了很多的资料解决这个问题,虽然有些方法能解决,但是总觉得总结的不是很全面,这里我自己在相对全面的总结一下,如果 ...
- 思科Cisco 交换机 VTP负载均衡的配置
思科Cisco 交换机 VTP负载均衡的配置 3560三层交换机配置: int ran fa0/23 - fa0/24 sw trunk encapsolution dot1q sw mode tru ...
- codeforce - 13A A.Numbers
A. Numbers time limit per test 1 second memory limit per test 64 megabytes input standard input outp ...
- Leetcode Tags(6)Math
一.204. Count Primes Count the number of prime numbers less than a non-negative number, n. Input: 10 ...
- (一) kinect概述
Kinect可以进行身体节点定位,姿势定位,人脸识别等功能,在此先做简单介绍,后续主要介绍插件的应用,毕竟自己开发识别过程太消耗时间. (注1:Kinect官方虽然提供了Unity的APi,但是方便起 ...
- todoList.html
待做的事情 {{item}} 完成 <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...
- vue-music 使用better-scroll遇到轮播图不能自动轮播
根据vue-music视频中slider组建的使用,当安装新版本的better-scroll,轮播组件,不能正常轮播 这是因为,better-scroll发布新版本之后,参数设置发生改变 这是旧版本: ...
- 【从刷面试题到构建知识体系】Java底层-synchronized锁-2偏向锁篇
上一篇通过构建金字塔结构,来从不同的角度,由浅入深的对synchronized关键字做了介绍, 快速跳转:https://www.cnblogs.com/xyang/p/11631866.html 本 ...