C# Aspose.Cells方式导入Excel文件
读取Excel 类 我返回的是DataTable 类型 也可以返回DataSet类型
public class XlsFileHelper
{
public DataTable ImportExcel(Stream filePath)
{
DataTable dt = new DataTable();
try
{
//打开文件,参数可以是文件的路径,也可以直接传入一个文件流
Aspose.Cells.Workbook workbook = new Aspose.Cells.Workbook(filePath);
//获取sheet表
Aspose.Cells.WorksheetCollection worksheets = workbook.Worksheets;
Aspose.Cells.Worksheet worksheet = null;
Aspose.Cells.Cells cell = null;
//默认第一行为列名 所以第一行不读,索引从第二行开始
int rowIndex = 0;
//从第一列读取
int colIndex = 0;
for (int i = 0; i < worksheets.Count; i++)
{
worksheet = worksheets[i];
//获取每个sheet表的所有单元格
cell = worksheet.Cells;
dt = cell.ExportDataTableAsString(rowIndex, colIndex, cell.MaxDataRow + 1, cell.MaxDataColumn + 1, true);
//表
dt.TableName = "table" + i.ToString();
}
worksheets.Clear();
worksheet = null;
worksheets = null;
workbook = null;
}
catch (Exception ex)
{
throw;
}
return dt;
}
}
读取excel文件的控制器方法,我传入的是一个HttpPostedFileBase
/// <summary>
/// 导入Excel文件
/// </summary>
/// <returns></returns>
[HttpPost]
public ActionResult Daoru(HttpPostedFileBase file)
{
var result = new OperationResult();
//名单类list
List<MingDan> list = new List<MingDan>();
try
{
XlsFileHelper helper = new XlsFileHelper();
//导入excel文件的方法(参数:IO流)
var data = helper.ImportExcel(file.InputStream);
//for循环获取表中列名值,长度小于表行数
for (int i = 0; i < data.Rows.Count; i++)
{
MingDan mingdan = new MingDan();
//姓名
mingdan.Name = data.Rows[i][0].ToString();
//证件类型
mingdan.CardType = data.Rows[i][1].ToString();
//证件号码
mingdan.CardCode = data.Rows[i][2].ToString();
//因为Aspose.Cells方式读取的是整个excel文件 包括它的工作簿,所以我在身份证号为空时中断循环
if (string.IsNullOrWhiteSpace(mingdan.CardCode))
{
break;
}
//出生日期
mingdan.Birth = data.Rows[i][3].ToString();
//性别
mingdan.Sex = data.Rows[i][4].ToString();
list.Add(mingdan);
}
}
catch (Exception e2)
{
return Json(result.ErrorResult("操作异常 : " + e2.Message));
}
//返回Json数据
return Json(list);
}
前端代码是这样的
<div>
<a href="javascript:void(0)" onclick="document.getElementById('txt_file').click()">导入名单</a>
<form action="@Url.Action("Daoru")" enctype="multipart/form-data" method="post" id="up" target="upiframe">
<input type="file" hidden name="file" id="txt_file" onchange="document.getElementById('up').submit()" />
<input type="hidden" name="num" id="num" value="" />
</form>
<
</div>
<iframe style="display:none" name="upiframe" id="upiframe"></iframe>
<script type="text/javascript">
window.onload = function () {
document.getElementById("upiframe").onload = function (e) {
try {
var upiframe = document.getElementById("upiframe"),
body = (upiframe.contentDocument || upiframe.contentWindow.document).body,
result = body.innerText || body.textContent || '';
//最终的Json数据data
data = JSON.parse(result);
} catch (er) {
console.log(er.message)
}
document.getElementById("up").reset();
};
}
</script>
C# Aspose.Cells方式导入Excel文件的更多相关文章
- 使用Aspose.Cells组件生成Excel文件
生成带表头的Excel文件,格式如下显示. 当然更复杂的一些也可以通过 合并单元格的方法 public void Merge(int firstRow, int firstColumn, int to ...
- .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)
.Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构) public cl ...
- phpexcel导入excel文件报the filename xxx is not recognised as an OLE file错误。
工作中频繁会用phpexcel类导入excel文件的数据到数据库,目前常用的excel文件格式有:xls.csv.xlsx. 刚开始,针对xls文件,使用如下程序,能正常运行: $objReader ...
- springMVC(5)---导入excel文件数据到数据库
springMVC(5)---导入excel文件数据到数据库 上一篇文章写了从数据库导出数据到excel文件,这篇文章悄悄相反,写的是导入excel文件数据到数据库.上一篇链接:springMVC(4 ...
- Java POI导入Excel文件
今天在公司需要做个导入Excel文件的功能,所以研究了一下,参考网上的一些资料总算是做出来了,在此记录一下防止以后忘记怎么弄. 本人用的是poi3.8,所以需要的JAR包如下: poi-3.8.jar ...
- YII使用PHPExcel导入Excel文件的方法
1.下载phpexcel,将压缩包中的classes复制到protected/extensions下并修改为PHPExcel. 2.修改YII配置文件config/main.php 'import'= ...
- excel数据 入库mysql 和 mysql数据 导入excel文件
1.excel数据入库mysql 首先准备excel文件, 标红的地方需要留意,一个是字段名所在行,一个表名对应页: 然后私用mysql工具 navicat, 选择数据库,然后导入文件, 选中相应ex ...
- java后端导入excel模板和导入excel文件去读数据
模板转载地址:https://www.cnblogs.com/zhangyangtao/p/9802948.html 直接上代码(我是基于ssm写的demo,导入文件目前只能读取.xls后缀的exce ...
- 利用kettle组件导入excel文件到数据库
利用kettle组件导入excel文件到数据库 1. 实现目标 把excel文件内容导入到目标表中:然后用java调用kettle的转换.excel文件的内容仅仅有两列,示比例如以下: wat ...
随机推荐
- 【xsy1596】旅行 期望+状压DP
题目大意:有$m$个人要从城市$1$开始,依次游览城市$1$到$n$. 每一天,每一个游客有$p_i$的概率去下一个城市,和$1-p_i$的概率结束游览. 当游客到达城市$j$,他会得到$(1+\fr ...
- 自动化测试框架的Step By Step搭建及测试实战(1)
1.1什么是自动化测试框架 1.什么是自动化框架 自动化框架是应用与自动化测试的程序框架,它提供了可重用的自动化测试模块,提供最基础的自动化测试功能,或提供自动化测试执行和管理功能的架构模块.它是由一 ...
- 高效的 JavaScript
避免使用 eval 或 Function 构造器 改写 eval 如果你需要函数,使用 function 不要使用 with 不要在要求性能的函数中使用 try-catch-finally 隔离 ev ...
- sql 指定时间 所在的周、月、季、年
DECLARE @TodayDateTime DATETIMEDECLARE @strToday NVARCHAR(19) DECLARE @TodayBeginDateTime DATETIMEDE ...
- [,,].length等于几
分别测试了谷歌.欧朋,火狐,QQ.搜狗,Edge,ie5.7.8.9.10.11 其中ie5,ie7,ie8得到的结果为3 其他均为2:如果最后一个逗号后面为空,则不识别最后一位
- 【Java基本功】很多人经常忽视的Java基础知识点
*.Java文件 问题:一个".java"源文件中是否可以包括多个类(不是内部类)?有什么限制? 答案:可以有多个类,但只能有一个public的类,并且public的类名必须与文件 ...
- vue-05-webpack安装-vue单文件启动
1, webpack是什么 1), 是一个打包工具, 比gulp, grunt更先进 2), 额外功能 项目部署上线, 清空目录等 hot module reload, 页面刷新后, 数据不变化 3) ...
- PHP 5.3中的命名空间使用方法
PHP的命名空间(namespace)是php5.3之后才有的.这个概念在C#中已经很早就有了,php中的namespace其实和c#的概念是一样的. 为什么php中要使用namespace? 假设如 ...
- PHP正则表达式修饰符的种类及介绍
◆i :如果在修饰符中加上"i",则正则将会取消大小写敏感性,即"a"和"A" 是一样的.◆m:默认的正则开始"^"和结 ...
- 解决SharePoint 2010拒绝访问爬网内容源错误
今天发现SP爬网出现了问题,持续时间蛮长的,一直爬不到内容. 解决方案: 这里有一条解决在SharePoint 2010搜索爬网时遇到的"拒绝访问错误"的小技巧. 首先要检查默认内 ...