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 导入 导出的更多相关文章

  1. c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出

    c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...

  2. NPOI导入导出EXCEL通用类,供参考,可直接使用在WinForm项目中

    以下是NPOI导入导出EXCEL通用类,是在别人的代码上进行优化的,兼容xls与xlsx文件格式,供参考,可直接使用在WinForm项目中,由于XSSFWorkbook类型的Write方法限制,Wri ...

  3. NPOI导入导出Excel

    .net mvc利用NPOI导入导出excel 注意:如何导出的提交方式ajax导出是失效的! 解决方案是:js处理l两个表单的提交  代码:  第一步. 在页面里面加入2个隐藏的iframe, 如下 ...

  4. .Net core NPOI导入导出Excel

    最近在想.net core NPOI 导入导出Excel,一开始感觉挺简单的,后来真的遇到很多坑.所以还是写一篇博客让其他人少走一些弯路,也方便忘记了再重温一遍.好了,多的不说,直接开始吧. 在.Ne ...

  5. c#.net 使用NPOI导入导出标准Excel (asp.net winform csharp)

    尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...

  6. 使用NPOI导入导出标准的Excel

    关于NPOI NPOI是POI项目的.NET版本,是由@Tony Qu(http://tonyqus.cnblogs.com/)等大侠基于POI开发的,可以从http://npoi.codeplex. ...

  7. ASP.NET- 使用NPOI导入导出标准Excel

    尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...

  8. 使用NPOI导入导出标准Excel

    尝试过很多Excel导入导出方法,都不太理想,无意中逛到oschina时,发现了NPOI,无需Office COM组件且不依赖Office,顿时惊为天人,怀着无比激动的心情写下此文. 曾使用过的方法 ...

  9. NPOI导入导出Excel数据

    代码: using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; using System; usi ...

  10. net core WebApi——使用NPOI导入导出操作

    目录 前言 NPOI 测试 小结 @ 前言 时间过得好快,在之前升级到3.0之后,就感觉好久没再动过啥东西了,之前有问到Swagger的中文汉化,虽说我觉得这种操作的意义不是太大,也是多少鼓捣了下,其 ...

随机推荐

  1. Virtex6 PCIe 超简版基础概念学习(一)

    文档版本 开发工具 测试平台 工程名字 日期 作者 备注 V1.0 ise14.7 DBF板 Day2/PCIETest1 2016.03.31 lutianfei none 参考资料: Sparta ...

  2. redhat5.8系统学习

    # redhat5.8系统学习 ### 简介-----------------------------redhat操作系统是红帽公司的收费版操作系统 ### 查看系统版本号-------------- ...

  3. CronTrigger中cron表达式使用

    1.定时任务,当执行是具体时间的时候,不会立即执行,而是到指定时间执行. 2.实现Job接口时候,类中要有无参的public构造方法. 3.表达式中共用七个字段,按顺序是秒.分.时.日.月.周.年,默 ...

  4. Web渗透实验:基于Weblogic的一系列漏洞

    1. 攻击机windows10 192.168.2.104 2. 靶机ip: 192.168.2.109(linux Ubantu) 192.168.2.111(windows2008R264位) 第 ...

  5. 关于搭建HTTPS服务器服务

    关于 HTTPS 的基本原理大家都已经不再陌生,今天和大家说说如何搭建一个支持 HTTPS 的服务端. 服务端的 HTTPS HTTPS 已经几乎成为了当前互联网推荐的通信方式,它能最大化保证信息传输 ...

  6. Python - json和simplejson比较(转)

    From:https://stackoverflow.com/questions/712791/what-are-the-differences-between-json-and-simplejson ...

  7. VBA 字符串操作

    Trim(string) 去掉string左右两端空白 Ltrim(string) 去掉string左端空白 Rtrim(string) 去掉string右端空白 Len(string) 计算stri ...

  8. chrome 设置代理服务器

    通过设置google chrome浏览器的代理服务器可以让google chrome浏览器通过代理服务器上网,可以隐藏本机的IP地址或者访问一些不能直接访问的网站. 工具/原料   google ch ...

  9. Unity3D学习笔记——初级知识

    一:Unity欢迎窗口对于初学者来说有很多有价值的信息,值得用户关注,以下将简要介绍这个窗口中的相关内容: 1.Video Tutorials: 提供unity相关的教程 ,包括用户手册 .组件手册以 ...

  10. python3 - 闭包

    # 定义一个函数def test(number): # 在函数内部再定义一个函数,并且这个函数用到外边函数的变量, # 那么将这个函数以及用到的一些变量称之为 闭包. def text_in(numb ...