.Net Core 读取,导入 excel数据 officeopenxml
/// <summary>
/// 导出Excel
/// </summary>
/// <param name="path">路径</param>
/// <param name="tableHeaders">表头,Dictionary<propname,name> propname属性名 ,name表头名称</param>
/// <param name="data"></param>
/// <returns></returns>
public static string Export(string path, Dictionary<string, string> tableHeaders, Object[] data)
{
string fileName = $"{Guid.NewGuid()}.xlsx";
var filePath = $"{path}\\{fileName}";
FileInfo file = new FileInfo(filePath);
try
{
using (ExcelPackage package = new ExcelPackage(file))
{ ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("exportdata");
var row = 1;
for (int i = 0; i < tableHeaders.Count; i++)
{
var headName = tableHeaders.ElementAt(i).Value;
worksheet.Cells[row, i + 1].Value = headName;
}
foreach (object item in data)
{
row++;
var propts = item.GetType().GetProperties();
for (int i = 0; i < tableHeaders.Count; i++)
{
var propName = tableHeaders.ElementAt(i).Key;
var check = propts.FirstOrDefault(o => o.Name.ToLower() == propName.ToLower());
if (check == null) worksheet.Cells[row, i + 1].Value = "";
else
{
var value = check.GetValue(item);
worksheet.Cells[row, i + 1].Value = value == null ? "" : value.ToString();
};
}
}
package.Save();
}
}
catch (Exception ex)
{
LogHelper.Singleton.Write(typeof(ExcelHelper), ex);
return null;
}
return filePath;
}
/// <summary>
/// 导入数据
/// </summary>
/// <param name="filePath">文件</param>
/// <returns></returns>
public static List<SchoolModel> ImportSchool(string filePath)
{
FileInfo file = new FileInfo(filePath);
List<SchoolModel> result = new List<SchoolModel>();
if (file.Length == 0) return null;
using (ExcelPackage package = new ExcelPackage(file))
{
//访问Excel的第一张表
ExcelWorksheet worksheet = package.Workbook.Worksheets[1];
//获取表格不为空的数
int rowCount = worksheet.Cells.Where(o=>o.Value!=null).Count();
//获取表格列数
int columnsCount = worksheet.Dimension.Columns;
//跳过表头从第二行,读取数据
for (int row = 2; row <= rowCount; row++)
{
if (row < 2) return null;
if (worksheet.Cells[row, 1].Value == null
|| worksheet.Cells[row, 2].Value == null
|| worksheet.Cells[row, 3].Value == null
|| worksheet.Cells[row, 4].Value == null
|| worksheet.Cells[row, 5].Value == null
|| worksheet.Cells[row, 6].Value == null)
{
continue;
}
result.Add(new SchoolModel()
{
SchoolName = worksheet.Cells[row, 1].Value.ToString(),
SchoolCode = worksheet.Cells[row, 2].Value.ToString(),
SubjectName = worksheet.Cells[row, 3].Value.ToString(),
SubjectCode = worksheet.Cells[row, 4].Value.ToString(),
SchoolSystem = worksheet.Cells[row, 5].Value.ToString(),
TuitionStandard = decimal.Parse(worksheet.Cells[row, 6].Value.ToString()),
}); }
package.SaveAs(file);
}
return result;
}
///数据模型类
public class SchoolModel
{
public string SchoolName { get; set; }
public string SchoolCode { get; set; }
public string SubjectName { get; set; }
public string SubjectCode { get; set; }
public string SchoolSystem { get; set; }
public decimal TuitionStandard { get; set; }
}
.Net Core 读取,导入 excel数据 officeopenxml的更多相关文章
- Asp.Net Core 导入Excel数据到Sqlite数据库并重新导出到Excel
Asp.Net Core 导入Excel数据到Sqlite数据库并重新导出到Excel 在博文"在Asp.Net Core 使用 Sqlite 数据库"中创建了ASP.NET Co ...
- 基于 Aspose.Cells与XML导入excel 数据----操作类封装
前言 导入excel数据, 在每个项目中基本上都会遇到,第三方插件或者基于微软office,用的最多的就是npoi,aspose.cells和c#基于office这三种方式,其中各有各的优缺点,在这也 ...
- thinkphp整合系列之phpexcel导入excel数据
一:导入phpexcel /ThinkPHP/Library/Vendor/PHPExcel 二:导入excel的函数 /** * 导入excel文件 * @param string $file ex ...
- springboot批量导入excel数据
1 背景 小白今天闲着没事,在公司摸鱼,以为今天有事无聊的一天,突然上头说小子,今天实现一下批量导入Excel数据吧,当时我的内心是拒绝的,然后默默打开idea. 2 介绍 2.1 框架 java本身 ...
- SQL Server服务器上需要导入Excel数据的必要条件
SQL Server服务器上需要导入Excel数据,必须安装2007 Office system 驱动程序:数据连接组件,或者Access2010的数据库引擎可再发行程序包,这样就不必在服务器上装Ex ...
- PLSQL Developer导入Excel数据
LSQL Developer导入Excel数据 最近处理将Excel数据导入Oracle的工作比较多.之前都是采用Sqlldr命令行导入的方式处理.每次导入不同格式的Excel表数据,都需要先把Exc ...
- 导入excel数据
前提条件:先要安装好EXCEL软件. 程序中经常要用到导入excel数据的功能.其实通过ole操作excel就简单的几行代码,但记性不好,经常要用经常要找, 还是作篇笔记吧. var ExcelApp ...
- (转)PLSQL Developer导入Excel数据
场景:近来在做加班记录的统计,主要是统计Excel表格中的时间,因为我对于Excel表格的操作不是很熟悉,所以就想到把表格中的数据导入到数据库中,通过脚本语言来统计,就很方便了!但是目前来看,我还没有 ...
- 结合bootstrap fileinput插件和Bootstrap-table表格插件,实现文件上传、预览、提交的导入Excel数据操作流程
1.bootstrap-fileinpu的简单介绍 在前面的随笔,我介绍了Bootstrap-table表格插件的具体项目应用过程,本篇随笔介绍另外一个Bootstrap FieInput插件的使用, ...
随机推荐
- vant ui TabBar封装
TabBar.vue基本上是放在App.vue里面,都存在 <template> <div id="app"> <home-tab-bar :tar- ...
- ASP.NET Core 3.x控制IHostedService启动顺序浅探
想写好中间件,这是基础. 一.前言 今天这个内容,基于于ASP.NET Core 3.x. 从3.x开始,ASP.NET Core使用了通用主机模式.它将WebHostBuilder放到了通用的I ...
- Java获取CPU序列号
获取CPU序列号 /** * 获取CPU序列号 * @return */ public static String getCpuId() throws IOException { Process pr ...
- 干货:不同场景容器内获取客户端源IP的方法
摘要:客户端和容器服务器之间可能存在多种不同形式的代理服务器,那容器中如何获取到客户端真实的源ip呢? k8s已经成为当今容器化的标准,人们在享受容器带来的高效与便利的同时,也遇到一些烦恼:客户端和容 ...
- 操作DOM对象
操作DOM对象 目录 操作DOM对象 1. 核心 2. 获得Dom节点 3. 更新节点 1. 操作文本 2. 操作CSS 4. 删除节点 5. 插入节点 1. 追加(将已存在的节点移到后面) 2. 创 ...
- 《ASP.NET Core项目开发实战入门》带你走进ASP.NET Core开发
<ASP.NET Core项目开发实战入门>从基础到实际项目开发部署带你走进ASP.NET Core开发. ASP.NET Core项目开发实战入门是基于ASP.NET Core 3.1 ...
- jmeter(一)
一.首先是下载:下载地址为:http://jmeter.apache.org/download_jmeter.cgi选择Binaries下的相应压缩包.ps:jmeter是开源项目,一般这种开源项目B ...
- 《Java从入门到失业》第四章:类和对象(4.2):String类
4.2String类 这一节,我们学习第一个类:String类.String翻译成汉语就是“字符串”,是字符的序列.我们知道,在Java中,默认采用Unicode字符集,因此字符串就是Unicode字 ...
- 学习go的一些笔记
反射 reflect type CfgSt struct{ Match *int64 `ini:"match"` Desc string `ini:"desc" ...
- [SSM项目]三-日志Logback
Logback介绍 Logback的主要模块 logback-access :与service容器集成,提供通过http访问日志的功能.即第三方软件可以通过这个模块来访问日志. logback-cla ...