一、搭建环境

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导入数据的更多相关文章

  1. .Net Core 使用 NPOI 导入Excel

    由于之前在网上查阅一些资料发现总是不能编译通过,不能正常使用,现把能正常使用的代码贴出: /// <summary> /// Excel导入帮助类 /// </summary> ...

  2. .Net core NPOI导入导出Excel

    最近在想.net core NPOI 导入导出Excel,一开始感觉挺简单的,后来真的遇到很多坑.所以还是写一篇博客让其他人少走一些弯路,也方便忘记了再重温一遍.好了,多的不说,直接开始吧. 在.Ne ...

  3. NPOI导入导出Excel数据

    代码: using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; using System; usi ...

  4. .net core利用MySqlBulkLoader大数据批量导入MySQL

    最近用core写了一个数据迁移小工具,从SQLServer读取数据,加工后导入MySQL,由于数据量太过庞大,数据表都过百万,常用的dapper已经无法满足.三大数据库都有自己的大数据批量导入数据的方 ...

  5. .NET Core使用NPOI导出复杂Word详解

    前言: 最近使用NPOI做了个导出Word文档的功能,关于使用.NET Core 导出Word文档的方式有很多.最终我为什么选择了NPOI来实现了这个功能,首先是NPOI是一个开源,免费且容易上手的第 ...

  6. .NET Core使用NPOI导出复杂,美观的Excel详解

    前言: 这段时间一直专注于数据报表的开发,当然涉及到相关报表的开发数据导出肯定是一个不可避免的问题啦.客户要求要导出优雅,美观的Excel文档格式的来展示数据,当时的第一想法就是使用NPOI开源库来做 ...

  7. 搜索引擎Solr系列(二): Solr6.2.1 从MySql中导入数据

     一:建立MySql测试表,如下图: 二:solr导入配置: 1.新建demo core文件夹,并修改managed-schema里面的配置文件建立索引字段: 2.把mysql-connector-j ...

  8. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  9. c#.net 使用NPOI导入导出标准Excel (asp.net winform csharp)

    尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...

随机推荐

  1. Java8新特性 - Stream API

    Stream是Java8中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找.过滤和映射数据等操作.使用Stream API对集合进行操作,就类似与使用SQL执行的数据库 ...

  2. JavaScript中valueOf、toString的隐式调用

    今天在群上有人问这样一个问题: 函数add可以实现连续的加法运算函数add语法如下add(num1)(num2)(num3)...;//注意这里是省略号哟,无限使用举例如下:add(10)(10)=2 ...

  3. ESP8266开发之旅 网络篇⑪ WebServer——ESP8266WebServer库的使用

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  4. SSO原理解析

    什么是单点登录 简单点说就是公司有A,B两个系统,我登录了A系统之后再跳转到B系统可以直接访问,而不需要再次登录B系统. 几种常见的单点登录实现方式 在讲解单点登录之前先讲解几个基本的概念: Cook ...

  5. jquery a标签的锚点点击的时候页面上缓慢滚动

    a标签增加一个名字触发效果: $(".transition").click(function(){ if (location.pathname.replace(/^\//, '') ...

  6. 百万年薪python之路 -- 前端CSS样式

    CSS样式 控制高度和宽度 width宽度 height高度 块级标签能设置高度和宽度,而内联标签不能设置高度和宽度,内联标签的高度宽度由标签内部的内容来决定. 示例: <!DOCTYPE ht ...

  7. 解决logback不打印mybatis的SQL日志的问题

    工作这么多年,今天还是因为Logback的这个问题稍微卡了一下,惭愧. 问题描述: logback配置了如下信息: <appender name="sql" class=&q ...

  8. node留言板

    这是一个nodejs + mongodb 的小项目,对数据库的增删改查 1. 引入项目依赖 "art-template": "^4.13.2", "b ...

  9. 【并发编程】Volatile原理和使用场景解析

    目录 一个简单列子 Java内存模型 缓存不一致问题 并发编程中的"三性" 使用volatile来解决共享变量可见性 volatile和指令重排(有序性) volatile和原子性 ...

  10. Airy Memory 内存清理 + 注册码

    链接: https://pan.baidu.com/s/1ZGxDtJBMhrRtBISvL1Lv0w 提取码: ccjs