转载:https://www.cnblogs.com/cang12138/p/5606130.html

上面的博友已经讲的很清楚了,但是我们在服务端是获取不到前端上传文件的绝对路径的(因为新浏览器有安全机制限制问题),也就是指定不了本地文件,所以我们一般把文件上传到服务器,再获取Excel里面的内容,这样我们可以防止导入出错时候方便查找,并且有一个备份,一般处理完后我们再选择是否把服务器的文件给删除掉

1.使用客户端控件实现上传(记住不是服务器控件)

上传代码如下,不懂可以参考https://www.cnblogs.com/cang12138/p/5606130.html

HTML代码如下(easyui的file控件好像不行,有兴趣的小伙伴可以尝试一下):

<div id="Execl">
<form id="form" action="../Handlers/AttendanceManagerHandler.ashx" method="post" enctype="multipart/form-data">
<input type="file" id="file1" name="file" onchange="fileOnchange()" />
<input id="selSheesName" name="selSheesName">
<a id="btnUpload" href="#" class="easyui-linkbutton" onclick="Upload()">导入</a>
</form>
</div>

jquery代码如下:

function fileOnchange() {
var formData = new FormData($('#form')[0]);
$.ajax({
type: 'post',
url: "../Handlers/AttendanceManagerHandler.ashx?funType=getsheetsname",
data: formData,
cache: false,
processData: false,//不处理数据
contentType: false,//不设置内容类型
dataType:"json",
}).success(function (response) {
//这个是easyui前端控件赋值方法
$('#selSheesName').combobox("loadData", response);
}).error(function () {
alert("下拉框获取失败!!!");
});
}
FormData解释参考这里https://developer.mozilla.org/zh-CN/docs/Web/API/FormData/Using_FormData_Objects
ajax的参数问题参考http://www.w3school.com.cn/jquery/ajax_ajax.asp 一般处理程序代码如下:
//获取前端传输过来的文件
HttpFileCollection files = HttpContext.Current.Request.Files;
//获取文件的访问权
HttpPostedFile posted = files[];
//获取服务器路径
string TempPath = System.IO.Path.GetTempPath();
//拼接成服务器的绝对路径
string filePath = TempPath + files[].FileName;
//上传文件到服务器
posted.SaveAs(filePath);

这里面关键是要获取文件控件的访问权问题,只有这样才能上传文件

至于后面的导入,参考https://www.cnblogs.com/cang12138/p/5606130.html

2.使用服务器控件完成Excel的导入

  (1)上传文件

  (2)创建连接   connStr = string.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=\"Excel 12.0;HDR=Yes;\"",filePath);这个连接串,全部支持,不需要判断扩展名是.xls  .xlsx

  (3)读取excel里面的内容

3.把数据导入到excel中,一般是我们读取我们的数据集,并把读取的数据给服务器上excel文件,再用a标签的href指向服务器地址,让客户点击标签另存到本地(代码:https://www.cnblogs.com/cang12138/p/5606130.html)

第三方插件的导入导出,以后有需求再说吧  未完待续。。。

Excel处理的更多相关文章

  1. 【造轮子】打造一个简单的万能Excel读写工具

    大家工作或者平时是不是经常遇到要读写一些简单格式的Excel? shit!~很蛋疼,因为之前吹牛,就搞了个这东西,还算是挺实用,和大家分享下. 厌烦了每次搞简单类型的Excel读写?不怕~来,喜欢流式 ...

  2. excel 日期/数字格式不生效需要但双击才会生效的解决办法

    原因: Excel2007设置过单元格格式后,并不能立即生效必须挨个双击单元格,才能生效.数据行很多.效率太低. 原因:主要是一些从网上拷贝过来的日期或数字excel默认为文本格式或特殊-中文数字格式 ...

  3. C# Excel导入、导出【源码下载】

    本篇主要介绍C#的Excel导入.导出. 目录 1. 介绍:描述第三方类库NPOI以及Excel结构 2. Excel导入:介绍C#如何调用NPOI进行Excel导入,包含:流程图.NOPI以及C#代 ...

  4. Word/Excel 在线预览

    前言 近日项目中做到一个功能,需要上传附件后能够在线预览.之前也没做过这类似的,于是乎就查找了相关资料,.net实现Office文件预览大概有这几种方式: ① 使用Microsoft的Office组件 ...

  5. ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-Excel导入和导出-自定义表模导入

    系列目录 前言 上一节使用了LinqToExcel和CloseXML对Excel表进行导入和导出的简单操作,大家可以跳转到上一节查看: ASP.NET MVC5+EF6+EasyUI 后台管理系统(6 ...

  6. C#中如何给Excel添加水印

    我们知道Microsoft Excel并没有内置的功能直接给Excel表添加水印,但是其实我们可以用其他变通的方式来解决此问题,如通过添加页眉图片或艺术字的方法来模仿水印的外观.所以在这篇文章中,我将 ...

  7. C#中如何在Excel工作表创建混合型图表

    在进行图表分析的时候,我们可能需要在一张图表呈现两个或多个样式的图表,以便更加清晰.直观地查看不同的数据大小和变化趋势.在这篇文章中,我将分享C#中如何在一张图表中创建不同的图表类型,其中包括如何在同 ...

  8. 【C#附源码】数据库文档生成工具支持(Excel+Html)

    [2015] 很多时候,我们在生成数据库文档时,使用某些工具,可效果总不理想,不是内容不详细,就是表现效果一般般.很多还是word.html的.看着真是别扭.本人习惯用Excel,所以闲暇时,就简单的 ...

  9. 免费高效实用的.NET操作Excel组件NPOI(.NET组件介绍之六)

    很多的软件项目几乎都包含着对文档的操作,前面已经介绍过两款操作文档的组件,现在介绍一款文档操作的组件NPOI. NPOI可以生成没有安装在您的服务器上的Microsoft Office套件的Excel ...

  10. C#通过NPOI操作Excel

    参考页面: http://www.yuanjiaocheng.net/webapi/create-crud-api-1-post.html http://www.yuanjiaocheng.net/w ...

随机推荐

  1. python_suit

    全局变量 Json:双引号       Suite :ddt中不能用 suit.add(test),应该用 suit.add(loader)

  2. bean的初始化和销毁方法

    1.bean的生命周期: bean创建---初始化----销毁的过程 容器管理bean的生命周期: 我们可以自定义初始化和销毁方法:容器在bean进行到当前生命周期的时候来调用我们自定义的初始化和销毁 ...

  3. 阿里云异构计算团队亮相英伟达2018 GTC大会

    摘要: 首届云原生计算国际会议(KubeCon + CloudNativeCon,China,2018)在上海举办,弹性计算研究员伯瑜介绍了基于虚拟化.容器化编排技术的云计算操作系统PouchCont ...

  4. Druid动态数据源配置

    上文已经讲了单个数据源的Druid的配置(http://www.cnblogs.com/nbfujx/p/7686634.html) Druid动态数据源配置 主要是继承AbstractRouting ...

  5. centos7.5部署ELk

    第1章 环境规划 1.1 ELK介绍       ELK是ElasticSerach.Logstash.Kibana三款产品名称的首字母集合,用于日志的搜集和搜索.      Elasticsearc ...

  6. Xcode 编辑器之关于Other Linker Flags相关问题

    一,概述 问题场景一 当从网上去下载一些之前的完整的项目的时候,用终端也 pod update了,但一运行,熟悉的linker错误就出来了. 解决办法 在Other Linker Flags(也即 O ...

  7. CDN(Content Delivery Network)内容分发网络

    CDN的全称是Content Delivery Network,即内容分发网络.其基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快.更稳定.通过在网络各处放置节 ...

  8. 发送邮件 django

    https://blog.csdn.net/qq_39138295/article/details/82527868 https://www.cnblogs.com/yoyoketang/p/1048 ...

  9. 中国HBase技术社区第一届Meetup资料大合集

    2018年6月6号,由中国HBase技术社区组织,阿里云主办的中国第一次HBase Meetup在北京望京阿里中心举行,来自阿里.小米.滴滴.360等公司的各位HBase的PMC.committer共 ...

  10. MFC DLL 导出函数的定义方式

    一直在鼓捣DLL,每天的工作都是调试一个一个的DLL,往DLL里面添加自己的代码,但是对于DLL一直不太了解啊!今天一查资料,才发现自己对于DLL编写的一些基本知识也不了解.要学习,这篇文章先总结DL ...