近期小编跟着团队一起开发ITOO3.0高校云平台项目,当中的收获是不言而喻滴,在项目中有个导入功能:导入学生信息;导入班级信息:导入教学楼信息等,在不知多少次的尝试之下,成功实现功能。

框架分析

详解一下

-第一步:在MVC框架的Client端新建目录

- 第二步:通过NPOI文件流(详细的专业名称不知道是叫啥。姑且称文件流)将保存在Client的Excel文件流传到WCF框架的Server端

- 第三步:在Server端中,新建目录保存Excel模板的xml文件



        Server端中的XML文件起到解析的作用,从而将Excel 中的数据插入Insert到数据表中


代码设计

上传Excel到Server

* Controller

private readonly IUploadFile upLoadService1 = ServiceFactory.GetUploadFileService();

#region ImportFlowBatch()+批量导入流程-徐露-2015年7月8日10:39:02

///

/// 批量导入流程

///

///

public ActionResult ImportFlowBatch()

{

#region 文件验证以及上传到指定目录 Client端

HttpPostedFileBase file = Request.Files[“files”];

string strFileName;

string strSavePath;

string ClientPath = AppDomain.CurrentDomain.BaseDirectory + “File\UpFile\”;

string strPaperId = “1”;

//这个是Client端的文件保存路径

        if (file == null || file.ContentLength <= 0)
{
ViewBag.error = "文件不能为空";
return View();
}
else
{
string strFilename = Path.GetFileName(file.FileName);
int intFilesize = file.ContentLength;//获取上传文件的大小单位为字节byte
string fileEx = System.IO.Path.GetExtension(strFilename);//获取上传文件的扩展名
string strNoFileName = System.IO.Path.GetFileNameWithoutExtension(strFilename);//获取无扩展名的文件名称
int Maxsize = 4000 * 1024;//定义上传文件的最大空间大小为4M
string FileType = ".xls,.xlsx";//定义上传文件的类型字符串 strFileName = strNoFileName + DateTime.Now.ToString("yyyyMMddhhmmss") + fileEx;
if (!FileType.Contains(fileEx))
{
ViewBag.error = "文件类型不正确。仅仅能导入xls和xlsx格式的文件";
//return View();
}
if (intFilesize >= Maxsize)
{
ViewBag.error = "上传文件超过4M。不能上传";
//return View();
}
strSavePath = Path.Combine(ClientPath, strFileName);
file.SaveAs(strSavePath);
}
#endregion #region 将Client端上传的文件 上传到Server端
FileUploadMessage myFileMessage = new FileUploadMessage();
string strDataFileName = file.FileName;
myFileMessage.FileName = strDataFileName;//文件名称
string CientPathName = ClientPath + strFileName;
using (FileStream fs = System.IO.File.OpenRead(CientPathName))
{
myFileMessage.FileData = fs;
try
{
upLoadService1.UploadFileMethod(myFileMessage);
}
catch { }
//关闭流
fs.Close();
}
#endregion
string[] HeadName = { "流程ID", "流程名称", "优先级", "是否启用(启用1。未启用0)", "流程Url", "时间戳", "是否删除" }; //调用执行 写数据库
if(upLoadService1.ServiceReadFile (strDataFileName ,strPaperId )==null) { return RedirectToAction("Index","ImportStudent");
}
else
{
DataTable table = upLoadService1 .ServiceReadFile (strDataFileName ,strPaperId )[0];
return File (Export .ExportManager .ExportExcel (table,HeadName ),"application/vnd.ms-excel", "流程导入错误列表" + ".xls"); }
}
#endregion

*在Service中读取Excel文件,写入数据库

须要加的三个:IUploadFile(接口)、UploadFile(实现类)、以及ServiceFactory(工厂)

        篇幅限制,详细代码不再粘贴。小编会详细上传Demo,另行下载

*XML配置

        针对每个导入的Excel都须要一个对应的XML配置文件,以便底层方法可以解析获取

        XML应统一放置在某一路径下,详细路径配置例如以下:

<appConfig>下加入节点
<add key="ExcelImportXMLPath" value="Models/ImportConfigXML"/>
即将配置文件存放路径放在了Service层的Models/ImportConfigXML目录下。 命名:各系统可依据详细情况详细命名,调用方法时须要传入XML文件名称称

详细XML配置可參考:

<?xml version="1.0" encoding="utf-8" ?>
<Excel name="导入流程模板">
<Sheet name="流程" table="FreshFlowEntity" primaryKey="FlowID" pkType="guid"> <Column name="流程名称" field="Name">
<DataType>string</DataType>
<ForeignKey isExist="false"></ForeignKey>
</Column>
<Column name="优先级" field="Sort" isNecessary="true">
<DataType>int</DataType>
<ForeignKey isExist="false"></ForeignKey>
</Column>
<Column name="是否启用(启用1,未启用0)" field="IsUse" isVerifyRepeat="false" >
<DataType>int</DataType>
<ForeignKey isExist="false"></ForeignKey>
</Column>
<Column name="流程Url" field="Url" isVerifyRepeat="false">
<DataType>string</DataType>
<ForeignKey isExist="false"></ForeignKey>
</Column>
<Column name="时间戳" field="TimeSpan" isNecessary="false" isVerifyRepeat="false" >
<DataType>DateTime</DataType>
<ForeignKey isExist="false"></ForeignKey>
</Column>
<Column name="是否删除" field="IsDelete" isVerifyRepeat="false">
<DataType>int</DataType>
<ForeignKey isExist="false"></ForeignKey>
</Column>
</Sheet>
</Excel>

以上就是做导入的基本流程,那是不是完善敲出代码就能正常执行呢,请见小编下文分析 link text

Excel数据导入___你hold住么(一)的更多相关文章

  1. kettle将Excel数据导入oracle

    导读 Excel数据导入Oracle数据库的方法: 1.使用PL SQL 工具附带的功能,效率比较低 可参考这篇文章的介绍:http://www.2cto.com/database/201212/17 ...

  2. 效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中【附源代码下载】) 转

    效率最高的Excel数据导入---(c#调用SSIS Package将数据库数据导入到Excel文件中[附源代码下载])    本文目录: (一)背景 (二)数据库数据导入到Excel的方法比较   ...

  3. Java代码实现excel数据导入到Oracle

    1.首先需要两个jar包jxl.jar,ojdbc.jar(注意版本,版本不合适会报版本错误)2.代码: Java代码   import java.io.File; import java.io.Fi ...

  4. 将Excel数据导入mysql数据库的几种方法

    将Excel数据导入mysql数据库的几种方法 “我的面试感悟”有奖征文大赛结果揭晓! 前几天需要将Excel表格中的数据导入到mysql数据库中,在网上查了半天,研究了半天,总结出以下几种方法,下面 ...

  5. 如何把excel数据导入数据库

    这里介绍2种把excel数据导入oracle数据库的方法. 1. 在excel中生成sql语句. 1)在数据列的右侧,第一行的任何位置输入="insert into table(xx,yyy ...

  6. excel 数据导入数据表

    环境: Windows server 2012  rm sql server  2012 excel 数据导入数据表 INSERT INTO [dbo].[AdminUser] SELECT [Adm ...

  7. C#使用oledb方式将excel数据导入到datagridview后数据被截断为 255 个字符

    问题描述:在使用oledb方式将excel数据导入到datagridview中,在datagridview单元格中的数据没有显示全,似乎只截取了数据源中的一段 解决方案:1.关于该问题,微软官方答案: ...

  8. excel数据导入到sqlserver中---------工作笔记

    调用页面: using System; using System.Collections.Generic; using System.Linq; using System.Web; using Sys ...

  9. c#将Excel数据导入到数据库的实现代码(OleDb)

    sing System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web ...

随机推荐

  1. EOJ 3000 ROT13加密和解密

    应用 ROT13 到一段文字上仅仅只需要检查字母顺序并取代它在 13 位之后的对应字母,有需要超过时则重新绕回 26 英文字母开头即可.A 换成 N.B 换成 O.依此类推到 M 换成 Z,然后串行反 ...

  2. float类型和double类型的二进制存储

    在32位环境下, float占用32位,double占用64位, 目前C/C++编译器标准都遵照IEEE制定的浮点数表示法来进行float,double运算.这种结构是一种科学计数法,用符号.指数和  ...

  3. Ubuntu14.04下初步使用MongoDB

    不多说,直接上干货! Ubuntu14.04下Mongodb(在线安装方式|apt-get)安装部署步骤(图文详解)(博主推荐) shell命令模式 输入mongo进入shell命令模式,默认连接的数 ...

  4. Apache-TomCat安装配置

    Apache-TomCat安装配置 本文是免安装版的Tomcat!(安装JavaJDK的步骤就不多述了!) (1)官网下载地址:https://tomcat.apache.org/download-8 ...

  5. MFC框架下Opengl窗口闪屏问题解决方案

    转自https://blog.csdn.net/niusiqiang/article/details/43116153 虽然启用了双缓冲,但是仍然会出闪屏的情况,这是由于OpenGL自己有刷新背景的函 ...

  6. 密信(Mesince)首创全自动邮件加密,颠覆传统邮件加密软件

    电子邮件泄密已经成为一个全球性的日益严峻的安全问题,解决这个问题的唯一有效办法就是电子邮件内容先加密后发送.然而,使用基于S/MIME标准的传统邮件加密软件进行邮件加密,需要用户具备一定的技术基础.用 ...

  7. 基础——(5)D Flip-Flop(D触发器)

    之前搞了一个 D-Latch,看一下下图是怎么变化的 In D-latch anytime its enabled the input D is going to be output at Q 使用c ...

  8. HDU 4535 吉哥系列故事——礼尚往来( 错排水题 )

    链接:传送门 思路:错排模板题,水题是非常浪费时间的. /*********************************************************************** ...

  9. [USACO 2009 Feb Gold] Fair Shuttle (贪心+优先队列)

    题目大意:有N个站点的轻轨站,有一个容量为C的列车起点在1号站点,终点在N号站点,有K组牛群,每组数量为Mi(1≤Mi≤N),行程起点和终点分别为Si和Ei(1≤Si<Ei≤N).计算最多有多少 ...

  10. java.lang.NoClassDefFoundError: org/apache/commons/collections4/ListValuedMap

    最近在使用java PiO导入导出Excle在windos本机上运行没有问题: 但是!!问题来了!放到Linux服务器上部署后出现异常 java.lang.NoClassDefFoundError: ...