一、搭建环境

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. C# Halcon联合编程问题(二)

    避免重复编辑同一篇随笔,有问题就开一个新的,哪怕会很短. 还是之前那个问题,halcon中的HObject转换为Bitmap的问题,在全网找相关的办法,三通道图像的HObject转换为C#中的Bitm ...

  2. 第一个shell脚本(一)

    第一个脚本 [root@ipha-dev71- exercise_shell]# ll total -rw-r--r-- root root Aug : test.sh [root@ipha-dev7 ...

  3. 04jmeter-Concurrency Thread Group

    1.下载插件Custom Thread Groups:参照:00jmeter安装相关 2.添加并发线程组 场景举例: 10个线程2分钟的加速时间5个加速步骤持有目标速率2分钟: 即: 2分钟除以5步, ...

  4. HDFS概述(一)

    HDFS概述(一) 1. HDFS产出的背景及定义 1.1 HDFS产生的背景 随着数据量越来越大,在一个操作系统存不下所有的数据,那么就分配到更多的操作系统管理的磁盘中,但是不方便管理和维护,迫切需 ...

  5. 告别10kb/s的Github访问速度

    由于种种原因,国内访问Github的体验一直不是很好.本文通过优化DNS缓存的方式,避免浏览器直接解析Github域名,来改善Github的访问速度. 本文分为如下三个部分: 通过IP地址查询获取访问 ...

  6. Leetcode Tags(4)Stack & Queue

    一.232. Implement Queue using Stacks private Stack<Integer> stack; /** Initialize your data str ...

  7. django-模板之now标签(七)

    1.在settings.py中设置成中国时区 2.index.html 3.显示

  8. SpringBoot与MybatisPlus3.X整合之字段类型处理器(八)

    pom.xml <dependencies> <dependency> <groupId>org.springframework.boot</groupId& ...

  9. 这次,我是如何监控服务器CPU和内存的

    背景 在新项目A中,要结合业务做性能测试.对于做过N次性能测试的我,这次有些巧妇有难无米之炊的感觉.以往的项目,服务器都是部署在AWS或者阿里云,像这样的云服务器厂商是可以通过轻松配置各种Dashbo ...

  10. 石头剪刀步(rps):dp,概率&期望

    既然已经给std了,直接扔代码啦.代码注释还是不错哒. 因为我也有点懵,不明白的或有不同见解的一定要在评论区喷我啊! #include<bits/stdc++.h> using names ...