/// <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的更多相关文章

  1. Asp.Net Core 导入Excel数据到Sqlite数据库并重新导出到Excel

    Asp.Net Core 导入Excel数据到Sqlite数据库并重新导出到Excel 在博文"在Asp.Net Core 使用 Sqlite 数据库"中创建了ASP.NET Co ...

  2. 基于 Aspose.Cells与XML导入excel 数据----操作类封装

    前言 导入excel数据, 在每个项目中基本上都会遇到,第三方插件或者基于微软office,用的最多的就是npoi,aspose.cells和c#基于office这三种方式,其中各有各的优缺点,在这也 ...

  3. thinkphp整合系列之phpexcel导入excel数据

    一:导入phpexcel /ThinkPHP/Library/Vendor/PHPExcel 二:导入excel的函数 /** * 导入excel文件 * @param string $file ex ...

  4. springboot批量导入excel数据

    1 背景 小白今天闲着没事,在公司摸鱼,以为今天有事无聊的一天,突然上头说小子,今天实现一下批量导入Excel数据吧,当时我的内心是拒绝的,然后默默打开idea. 2 介绍 2.1 框架 java本身 ...

  5. SQL Server服务器上需要导入Excel数据的必要条件

    SQL Server服务器上需要导入Excel数据,必须安装2007 Office system 驱动程序:数据连接组件,或者Access2010的数据库引擎可再发行程序包,这样就不必在服务器上装Ex ...

  6. PLSQL Developer导入Excel数据

    LSQL Developer导入Excel数据 最近处理将Excel数据导入Oracle的工作比较多.之前都是采用Sqlldr命令行导入的方式处理.每次导入不同格式的Excel表数据,都需要先把Exc ...

  7. 导入excel数据

    前提条件:先要安装好EXCEL软件. 程序中经常要用到导入excel数据的功能.其实通过ole操作excel就简单的几行代码,但记性不好,经常要用经常要找, 还是作篇笔记吧. var ExcelApp ...

  8. (转)PLSQL Developer导入Excel数据

    场景:近来在做加班记录的统计,主要是统计Excel表格中的时间,因为我对于Excel表格的操作不是很熟悉,所以就想到把表格中的数据导入到数据库中,通过脚本语言来统计,就很方便了!但是目前来看,我还没有 ...

  9. 结合bootstrap fileinput插件和Bootstrap-table表格插件,实现文件上传、预览、提交的导入Excel数据操作流程

    1.bootstrap-fileinpu的简单介绍 在前面的随笔,我介绍了Bootstrap-table表格插件的具体项目应用过程,本篇随笔介绍另外一个Bootstrap FieInput插件的使用, ...

随机推荐

  1. 1.spring boot初始化项目

    初始化spring boot项目的方式非常多,如使用Spring Tool Suite.使用IntelliJ IDEA.使用NetBeans.在start.spring.io网站中.curl命令.sp ...

  2. Java Jar源码反编译工具那家强

    本文介绍下Java Jar常见的反编译工具,并给出使用感受. 反编译JAR能干什么: 排查问题.分析商业软件代码逻辑,学习优秀的源码思路. JD-GUI 下载地址:http://java-decomp ...

  3. C014:不用算术分割显示逆序三位数

    程序: #include "stdafx.h" int _tmain(int argc, _TCHAR* argv[]) { int handred,ten,ge; do{ pri ...

  4. leetcode刷题-61旋转链表

    题目 给定一个链表,旋转链表,将链表每个节点向右移动 k 个位置,其中 k 是非负数. 示例 1: 输入: 1->2->3->4->5->NULL, k = 2输出: 4 ...

  5. Prmise.all的简单实现

    注意点 入参一般是个由Promise实例组成的数组,但是也可以不是数组,但必须具有 Iterator 接口,且返回的每个成员都是 Promise 实例.若参数如果不是 Promise 实例,就会先调用 ...

  6. ThinkPHP6.0 多应用模式 部署 Layuiadmin 单页版

    TP6.0中的路由省略应用名只能用入口文件绑定应用 和 域名绑定应用,经过测试,最后得出域名绑定应用是最合适的部署方式.如果有更好的部署方案,欢迎分享.QQ:23426945 1. 下载TP6.0,引 ...

  7. path.resolve和path.join的区别

    // test.js const path = require('path') let x1 = path.resolve('/目录1/目录2', '/目录3/目录4/') let x2 = path ...

  8. Git+Gitlab+Ansible剧本实现一键部署动态网站(5)

    项目前言 之前已经写了一篇关于git和ansible的博客<Git+Gitlab+Ansible剧本实现一键部署Nginx–技术流ken>.关于git,gitliab,ansible在我以 ...

  9. 1.4Hadoop伪分布式安装

  10. FTL指令常用标签及语法

    FTL指令常用标签及语法注意:使用freemaker,要求所有标签必须闭合,否则会导致freemaker无法解析. freemaker注释:<#-- 注释内容 -->格式部分,不会输出 - ...