Mego(04) - NET简单实现EXCEL导入导出
前言
相信做过信息系统的朋友都会遇到EXCEL导入导出的相关开发,做过不少EXCEL导入导出后总结起来大致有如下几种方式实现:
- ADO.NET的OldDb或ODBC连接EXCEL使用DataTable来读取数据。
- Microsoft.Office.Interop.Excel用微软提供的组件操作WorkSheet对象。
- 使用一些第三方的库比如Fast Excel、ExcelDataReader等等。
今天要向大家介绍的更简单的方式来实现日常开发的各种EXCEL导入导出需求。
简单导入
我们还是使用ADO.NET中的System.Data.OleDb做为底层,这种方式会很高效。先定义一个对象用来承载数据。
public class Product
{
public int Id { get; set; }
public string Code { get; set; }
public string Name { get; set; }
public int Category { get; set; }
public bool IsValid { get; set; }
}
声明一个连接字符串模型如下
private const string conStr =
@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties='Excel 12.0 Xml;HDR=YES'";
最后声明一个访问EXCEL的上下文
public class ExcelContext : DbContext
{
public ExcelContext(string filename)
: base(string.Format(conStr, filename), "System.Data.OleDb.Excel")
{
this.Configuration.EnableAutoConversionStorageTypes = true;
}
public DbSet<Product> Products { get; set; }
}
到这里准备工作就完成了,然后我们就能从数据源提取数据如下所示:
using (var context = new ExcelContext("sample.xls"))
{
var data = context.Products.ToArray();
}
只要两行代码就能获取数据转成NET的对象,如果这里有一个能访问业务数据库的上下文就能直接导入数据,例如下面的临时代码:
using (var context = new OracleContext())
{
context.Products.AddRange(data);
context.Executor.Execute();
}
到此我们都以一个很简单的方式就能完成从EXCEL提取并向数据库导入数据的工作。
万能导入
也许你会考虑到导入EXCEL的格式会很多,不能每次都来定义一个上下文和数据对象类,这里我们可以定义一种通用方式来读取EXCEL。
我们还是利用上面的连接字符串再定义一个通用的数据上下文。
public class AnonymouExcelContext : DbContext
{
public AnonymouExcelContext(string filename)
: base(string.Format(conStr, filename), "System.Data.OleDb.Excel")
{
this.Configuration.EnableAutoConversionStorageTypes = true;
}
}
接着我们利用C#的匿名对象来读取数据。
using (var context = new ExcelContext("sample.xls"))
{
var item = new { Id = 1, Name = "P", IsValid = false };
var data = context.Set(item, "Products").Where(a => a.Id > 20).ToArray();
}
我们先定义一个匿名对象,其实就是以匿名形式声明了将要导入数据的字段,使用匿名类型还一个好处就是可以进行LINQ操作,例如上面的代码。
导出数据
导出EXCEL也是个比较麻烦的事,首先你需要写表头,然后再写入数据,可能在不同的场景下你需要重要写导出的代码这个在使用Microsoft.Office.Interop.Excel导出时特别严重。这里我们还是用上面的数据上下文来导出数据。
首先我们先创建一些数据用于导出。
Random r = new Random();
var products = Enumerable.Range(0, 1000).Select(i => new Product()
{
Id = i,
Name = "Product " + i.ToString(),
Category = r.Next(1, 10),
Code = "P" + i.ToString(),
IsValid = true
});
我们需要创建一个空白的EXCEL文件,这里不声明代码了。
最后就是写入表头和内容:
using (var context = new ExcelContext(filename))
{
var operate = context.Database.Manager.CreateTable<Product>();
context.Executor.Execute(operate);//创建表头
context.Products.AddRange(products);
context.Executor.Execute();//写入数据
}
同样的匿名对象也是同样可以如此操作,
创建数据
Random r = new Random();
var items = Enumerable.Range(0, 1000).Select(i => new
{
Id = i,
Name = "Product " + i.ToString(),
Category = r.Next(1, 10),
IsValid = true
}).ToArray();
写入数据
using (var context = new ExcelContext(filename))
{
var item = items[0];
var operate = context.Database.Manager.CreateTable(item.GetType(),
DbName.NameOnly("Sheet1$"));
context.Executor.Execute(operate);
context.Set(item, "[Sheet1$]").AddRange(items);
context.Executor.Execute();
}
复杂EXCEL导入
通过上面的代码已经可以满足大多数的开发需求,不过业务需求永远无止境,不知道下面EXCEL导入案例大家是否有遇到。
客户需要一次导入上万条订单加明细数据,在正式导入到数据库之前还要在系统界面上浏览确认及修改,确认无误后才发命令写入到数据库。(最麻烦的是这是个基于WEB的系统)。
上传EXCEL是少不了的,但是浏览修改会麻烦一点,不过基于良好的用户体验需要把EXCEL保存在服务器的临时位置,然后分页向用户显示数据并提供修改功能,最后当用户确认后才提交到数据库。
首先我们先创建一个相对复杂的数据上下文。
internal class ComplexContext : DbContext
{
public ComplexContext(string filename)
: base(string.Format(conStr, filename), "System.Data.OleDb.Excel")
{
this.Configuration.EnableAutoConversionStorageTypes = true;
}
public DbSet<Order> Orders { get; set; }
public DbSet<OrderDetail> OrderDetails { get; set; }
public DbSet<Customer> Customers { get; set; }
public DbSet<Product> Products { get; set; }
}
这里忽略数据类的定义,这里的数据间关系是订单有多个明细,订单关系一个客户,明细关系一个产品,对于EXCEL而言这已经很复杂了。
不过在这里你可以很容易的查询所有订单及订单明细,过滤加分页向用户显示数据,如下所示
using (var context = new ComplexContext("sample.xls"))
{
var query = from a in context.Orders.Include(a=>a.Details)
where a.Id > 4
select a;
var items = query.Take(10).Skip(20).ToArray();
}
我们直接上个图来证明下数据的正确性。

以上代码都已上传Github。
以上都是基于Mego框架实现的对EXCEL操作,当然Mego还支持许多数据库,欢迎大家试用。
Mego(04) - NET简单实现EXCEL导入导出的更多相关文章
- 有史以来功能最全,使用最简单的excel导入/导出工具
Github地址:https://github.com/xuanbg/Utility. 还有其他一些福利,请各位园友自取. 构造方法 1.用于导出Excel文件 NpoiHelper(ExcelVer ...
- 简单excel导入导出
import java.io.File;import java.io.IOException; import jxl.Cell;import jxl.Sheet;import jxl.Workbook ...
- 一个基于POI的通用excel导入导出工具类的简单实现及使用方法
前言: 最近PM来了一个需求,简单来说就是在录入数据时一条一条插入到系统显得非常麻烦,让我实现一个直接通过excel导入的方法一次性录入所有数据.网上关于excel导入导出的例子很多,但大多相互借鉴. ...
- Excel导入导出工具(简单、好用且轻量级的海量Excel文件导入导出解决方案.)
Excel导入导出工具(简单.好用且轻量级的海量Excel文件导入导出解决方案.) 置顶 2019-09-07 16:47:10 $9420 阅读数 261更多 分类专栏: java 版权声明:本 ...
- Excel导入导出的业务进化场景及组件化的设计方案(上)
1:前言 看过我文章的网友们都知道,通常前言都是我用来打酱油扯点闲情的. 自从写了上面一篇文章之后,领导就找我谈话了,怕我有什么想不开. 所以上一篇的(下)篇,目前先不出来了,哪天我异地二次回忆的时候 ...
- 关于Excel导入导出的用例设计
目前,为方便操作,很多系统都会增加批量导入导出的功能.文件导入导出一般格式都是excel.由于用户直接在excel在填写内容,无法控制填写的格 式,加上excel解析比较困难,所以一般涉及到excel ...
- Octopus——excel导入导出工具
Octopus Octopus是一个简易的Excel导入导出工具.目前主要就两个功能: 导入:将excel中一行数据转换为指定的java对象,并通过指定的正则表达式检查合法性. 导出:按照给定的xml ...
- JeeSite中Excel导入导出
在各种管理系统中,数据的导入导出是经常用到的功能,通常导入导出以Excel.CSV格式居多.如果是学习的过程中,最好是自己实现数据导入与导出的功能,然而在项目中,还是调用现成的功能比较好.近期一直使用 ...
- 土制Excel导入导出及相关问题探讨
转载请注明出处https://www.cnblogs.com/funnyzpc/p/10392085.html 新的一年,又一个开始,不见收获,却见年龄,好一个猪年,待我先来一首里尔克的诗: < ...
随机推荐
- 从嵌入式linux到android应用开发
时间过得很快,转眼之间已经到新公司一个月了.虽然学到了一些移动开发的知识,但是觉得离我的目标还很远,完全没能达到我想要的水平.以前产品都是自己主导的,需要完成什么,计划什么也是自己主导,现在得从头 ...
- TortoiseSVN服务器ip地址修改后如何使用
TortoiseSVN是很多人特别是程序员经常使用的工作追述工具,在长期使用过程中难免会遇到服务器迁移ip地址变更的问题.那么在服务器ip地址变化之后,我们要如何继续使用呢?步骤其实非常简单,下面我们 ...
- IBM SPSS 实习总结
2015过完年,我知道导师要出国了,自己也算是水了一个idea 的论文.希望研二能找个实习,早听说西安IBM这边有学长在里面实习过,2月底联系了一下简历就塞了过去.面试就在锦业一路软件园他们上班的地方 ...
- HMM:隐马尔科夫模型-维特比算法
http://blog.csdn.net/pipisorry/article/details/50731584 目标-解决HMM的基本问题之二:给定观察序列O=O1,O2,-OT以及模型λ,如何选择一 ...
- ROS_Kinetic_19 群机器人框架示例(micros swarm framework)
ROS_Kinetic_19 群机器人框架示例(micros swarm framework) 官方网址:http://wiki.ros.org/micros_swarm_framework 这个包是 ...
- UNIX环境高级编程——线程同步之条件变量以及属性
条件变量变量也是出自POSIX线程标准,另一种线程同步机制.主要用来等待某个条件的发生.可以用来同步同一进程中的各个线程.当然如果一个条件变量存放在多个进程共享的某个内存区中,那么还可以通过条件变量来 ...
- 竞价拍卖理论的介绍(RTB模型中使用第二竞价模型,为的是纳什平衡,保护所有多方利益)
英式拍卖 是最普通的拍卖方式,其形式是拍卖过程中,竞价按阶梯,从低到高,依次递增.最终由出价最高者获得拍卖物品(竞买人变成买受人). The first price auction: a form o ...
- android studio编译慢的问题
1.修改android studio的使用堆内存,根据自己电脑的内存,尽量设置的大一点,点击help->如下图: 2.接下来设置使用离线gradle构建,一开始就是使用了内置的默认路径gradl ...
- Chapter 1 Securing Your Server and Network(13):配置端点安全性
原文出处:http://blog.csdn.net/dba_huangzj/article/details/38489765,专题目录:http://blog.csdn.net/dba_huangzj ...
- JAVA之旅(十二)——Thread,run和start的特点,线程运行状态,获取线程对象和名称,多线程实例演示,使用Runnable接口
JAVA之旅(十二)--Thread,run和start的特点,线程运行状态,获取线程对象和名称,多线程实例演示,使用Runnable接口 开始挑战一些难度了,线程和I/O方面的操作了,继续坚持 一. ...