NPOI 导入 导出
using NPOI.XSSF.UserModel;
using System.IO;
导入
/// <summary>
/// Excel转换DataTable
/// </summary>
/// <param name="FilePath">文件的绝对路径</param>
/// <returns>DataTable</returns>
public static DataTable ExcelInput(string FilePath)
{
//第一行一般为标题行。
DataTable table = new DataTable();
//根据路径通过已存在的excel来创建HSSFWorkbook,即整个excel文档
XSSFWorkbook hssfworkbook;
using (FileStream file = new FileStream(FilePath, FileMode.Open, FileAccess.Read))
{
XSSFWorkbook workbook = new XSSFWorkbook(file);
XSSFSheet sheet = (XSSFSheet)workbook.GetSheetAt(0);
//获取excel的第一个sheet
//获取Excel的最大行数
int rowsCount = sheet.PhysicalNumberOfRows; //为保证Table布局与Excel一样,这里应该取所有行中的最大列数(需要遍历整个Sheet)。
//为少一交全Excel遍历,提高性能,我们可以人为把第0行的列数调整至所有行中的最大列数。
int colsCount = sheet.GetRow(0).PhysicalNumberOfCells;
for (int i = 0; i < colsCount; i++)
{
table.Columns.Add(i.ToString());
}
for (int x = 0; x < rowsCount; x++)
{ DataRow dr = table.NewRow();
for (int y = 0; y < colsCount; y++)
{
var row = sheet.GetRow(x);
if (row != null)
{
var column = row.GetCell(y);
if (column != null)
{
dr[y] = sheet.GetRow(x).GetCell(y).ToString();
}
}
}
table.Rows.Add(dr);
}
sheet = null;
workbook = null;
}
return table;
}
导出
[Ajax] public AjaxResult ExportWithdrawExcel(int id) { bool ifSuccess = false; string msg = ""; string templatePath = Server.MapPath("\\Content\\template\\WithdrawInfo.xlsx"); string resultPath = ""; try { var entity = _withdrawRequestService.GetYstObjById(id); WithdrawRequestModel requestModel = entity.ToModel(); resultPath = "\\Content\\template\\" + requestModel.BillCode + "_" + DateTime.Now.Second + ".xlsx"; string savePath = Server.MapPath(resultPath); IWorkbook exportFile = new XSSFWorkbook(templatePath);
ISheet sheet1 = exportFile.GetSheet("相关提现订单"); var list = _withdrawOrderListService.GetWithdrawOrderListByWithdrawRequestId(requestModel.Id); var modelList = new List<WithdrawOrderListModel>(); foreach (var item in list) { var model = new WithdrawOrderListModel(); if (item != null) { model = item.ToModel(); } modelList.Add(model); } var gt = modelList.ToArray();
System.Data.DataTable dt = IListOut(modelList); int rowCount = dt.Rows.Count; int colCount = dt.Columns.Count; object[,] dataArray = new object[rowCount + 1, colCount]; for (int j = 0; j < rowCount; j++) { IRow row = sheet1.CreateRow(j + 12); for (int i = 0; i < colCount; i++) {
switch (dt.Columns[i].ColumnName) { case "EndDate": { row.CreateCell(0).SetCellValue(dt.Rows[j][i].ToString()); break; } case "UserName": { row.CreateCell(1).SetCellValue(dt.Rows[j][i].ToString()); break; } case "BankName": { row.CreateCell(2).SetCellValue(dt.Rows[j][i].ToString()); break; } case "OrgId": { row.CreateCell(3).SetCellValue(dt.Rows[j][i].ToString()); break; } case "CardNo": { row.CreateCell(4).SetCellValue(dt.Rows[j][i].ToString()); break; } case "Amount": { row.CreateCell(5).SetCellValue(dt.Rows[j][i].ToString()); break; } case "CreateDate": { row.CreateCell(6).SetCellValue(dt.Rows[j][i].ToString()); break; } case "WithdrawTypeShow": { row.CreateCell(7).SetCellValue(dt.Rows[j][i].ToString()); break; } case "OrderCode": { row.CreateCell(8).SetCellValue(dt.Rows[j][i].ToString()); break; } case "OrderTitle": { row.CreateCell(9).SetCellValue(dt.Rows[j][i].ToString()); break; } case "UserTypeShow": { row.CreateCell(10).SetCellValue(dt.Rows[j][i].ToString()); break; } case "UniqueCode": { row.CreateCell(11).SetCellValue(dt.Rows[j][i].ToString()); break; } } } } sheet1.GetRow(1).GetCell(1).SetCellValue(requestModel.BillCode.ToString()); sheet1.GetRow(2).GetCell(1).SetCellValue(requestModel.WithdrawTypeShow.ToString()); sheet1.GetRow(3).GetCell(1).SetCellValue(requestModel.Creator.ToString()); sheet1.GetRow(4).GetCell(1).SetCellValue(requestModel.SubmitMan.ToString()); sheet1.GetRow(5).GetCell(1).SetCellValue(requestModel.CheckMan.ToString()); sheet1.GetRow(6).GetCell(1).SetCellValue(requestModel.AuditMan.ToString()); sheet1.GetRow(7).GetCell(1).SetCellValue(requestModel.CheckMan.ToString()); sheet1.GetRow(6).GetCell(1).SetCellValue(requestModel.Remark.ToString()); sheet1.GetRow(1).GetCell(5).SetCellValue(requestModel.BillDate.ToString()); sheet1.GetRow(2).GetCell(5).SetCellValue(requestModel.BillAmount.ToString()); sheet1.GetRow(3).GetCell(5).SetCellValue(requestModel.CreatedOnUTC.ToString()); sheet1.GetRow(4).GetCell(5).SetCellValue(requestModel.SubmitDate.ToString()); sheet1.GetRow(5).GetCell(5).SetCellValue(requestModel.CheckDate.ToString()); sheet1.GetRow(6).GetCell(5).SetCellValue(requestModel.AuditDate.ToString());
FileStream sw = System.IO.File.Create(savePath); exportFile.Write(sw); sw.Close(); ifSuccess = true; } catch (Exception e) { msg = e.Message; if (e.InnerException != null) msg += e.InnerException.Message; } JsonSerializerSettings js = new JsonSerializerSettings(); js.ReferenceLoopHandling = ReferenceLoopHandling.Ignore; return new AjaxResult(ifSuccess, JsonConvert.SerializeObject(resultPath, Formatting.Indented, js), msg);
}
NPOI 导入 导出的更多相关文章
- c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出
c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...
- NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中
以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...
- NPOI导入导出Excel
.net mvc利用NPOI导入导出excel 注意:如何导出的提交方式ajax导出是失效的! 解决方案是:js处理l两个表单的提交 代码: 第一步. 在页面里面加入2个隐藏的iframe, 如下 ...
- .Net core NPOI导入导出Excel
最近在想.net core NPOI 导入导出Excel,一开始感觉挺简单的,后来真的遇到很多坑.所以还是写一篇博客让其他人少走一些弯路,也方便忘记了再重温一遍.好了,多的不说,直接开始吧. 在.Ne ...
- c#.net 使用NPOI导入导出标准Excel (asp.net winform csharp)
尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...
- 使用NPOI导入导出标准的Excel
关于NPOI NPOI是POI项目的.NET版本,是由@Tony Qu(http://tonyqus.cnblogs.com/)等大侠基于POI开发的,可以从http://npoi.codeplex. ...
- ASP.NET- 使用NPOI导入导出标准Excel
尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...
- 使用NPOI导入导出标准Excel
尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...
- NPOI导入导出Excel数据
代码: using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; using System; usi ...
- net core WebApi——使用NPOI导入导出操作
目录 前言 NPOI 测试 小结 @ 前言 时间过得好快,在之前升级到3.0之后,就感觉好久没再动过啥东西了,之前有问到Swagger的中文汉化,虽说我觉得这种操作的意义不是太大,也是多少鼓捣了下,其 ...
随机推荐
- TortoiseSVN客户端使用方法
SVN对于程序开发来说是非常重要的东西,它是非常不错的版本管理工具,下面介绍一下TortoiseSVN客户端的使用方法. 工具/原料 TortoiseSVN 方法/步骤 如果没有TortoiseS ...
- Atitit。Tree文件解析器的原理流程与设计实现 java c# php js
Atitit.Tree文件解析器的原理流程与设计实现 java c# php js 1. 解析原理与流程1 1.1. 判断目录 ,表示服 dirFlagChar = "└├─&quo ...
- PILE读书笔记_文件I/O
open函数 int open(const char *pathname, int flags, mode_t mode); 参数说明: (1)pathname: 表示要打开的文件路径 (2)flag ...
- va_list可变参数
可变参数函数实现 va_list,va_start,va_arg,va_end va可变参数意思,variable-argument. 1. 头文件及实现 linux中定义在gcc头文件中,stdar ...
- MySQL同步状态双Yes的假象及 seconds_behind_master的含义
MySQL同步状态双Yes的假象及seconds_behind_master的含义 近期由于特殊原因有一台主库宕机了一个小时没有处理,说起来这是个挺不好啥意思的事情,但是由于这个事情反而发现个比较 ...
- EasyUI DataGrid 相同连续列合并
扩展方法:$.extend($.fn.datagrid.methods, { autoMergeCells: function(jq, fields) { return jq.each(functio ...
- 自定义View -- 柱状图 我也来自定义个柱状图来玩玩
遇到要用到图的时候总是再找第三方开源,但有时这个图非常简单,用第三方开源来用的话有点得不偿失,所以我就自己撸了个柱状图出来 当然你如果觉得需求很复杂,那么你可以去使用这些开源 MPAndroidCha ...
- 第一百七十七节,jQuery,知问前端--概述及 jQuery UI
jQuery,知问前端--概述及 jQuery UI 学习要点: 1.项目介绍 2.jQuery UI 3.UI 主题 一.项目介绍 我们重点仿照“知乎”的架构模式来搭建界面和布局,以及大部分前端功能 ...
- 用ActivatedRoute获取url中的参数
突然让我用ActivatedRoute import {Injectable} from "@angular/core"; import {ActivatedRoute} from ...
- hdu 5374 Tetris(模拟)
pid=5374">题目链接:hdu 5374 Tetris 模拟.每次进行操作时推断操作是否合法,合法才运行,否则跳过.每次一个token落地,推断一下是否有消除整行. #inclu ...