c# NPOI aspx导出数据
- public static class XSSFWorkbook_Excel
- {
- /// <summary>
- /// GetExcel
- /// </summary>
- /// <param name="list">结果结合</param>
- /// <param name="parms_header">要输出的字段名</param>
- /// <param name="filename">文件名</param>
- /// <returns></returns>
- public static bool GetExcel(IList list, IDictionary<string, string> parms_header, string filename)
- {
- HttpContext curContext = HttpContext.Current;
- try
- {
- MemoryStream ms = new MemoryStream();
- EntityListToExcel(list, parms_header, "Sheet1").Write(ms);
- curContext.Response.Clear();
- curContext.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(filename, Encoding.UTF8) + ".xlsx");
- curContext.Response.AddHeader("Content-Length", ms.ToArray().Length.ToString());
- curContext.Response.ContentEncoding = Encoding.UTF8;
- curContext.Response.ContentType = "application/ms-excel";
- curContext.Response.BinaryWrite(ms.ToArray());
- ms.Close();
- ms.Dispose();
- curContext.Response.Flush();
- curContext.Response.End();
- }
- catch (Exception ex)
- {
- curContext.Response.Flush();
- curContext.Response.End();
- }
- finally
- {
- curContext.Response.Flush();
- curContext.Response.End();
- }
- return true;
- }
- /// <summary>
- /// GetExcel
- /// </summary>
- /// <param name="list">结果结合</param>
- /// <param name="parms_header">要输出的字段名</param>
- /// <param name="filename">文件名</param>
- /// <param name="path">下载地址</param>
- /// <returns></returns>
- public static bool GetExcel(IList list, IDictionary<string, string> parms_header, string filename, out string path)
- {
- path = "/Export/" + filename + ".xlsx";
- try
- {
- using (FileStream stm = File.OpenWrite(AppDomain.CurrentDomain.BaseDirectory + path))
- {
- EntityListToExcel(list, parms_header, "Sheet1").Write(stm);
- }
- return true;
- }
- catch (Exception ex)
- {
- return false;
- }
- }
- public static XSSFWorkbook EntityListToExcel(IList list, IDictionary<string, string> parms_header, string sheetName)
- {
- try
- {
- XSSFWorkbook workbook = new XSSFWorkbook();
- //workbook.SetSheetHidden(,)
- //HSSFWorkbook workbook = new HSSFWorkbook();
- ISheet sheet = workbook.CreateSheet(sheetName);
- IRow row = sheet.CreateRow();
- List<string> keys = parms_header.Keys.ToList();
- for (int i = ; i < keys.Count; i++)
- {
- row.CreateCell(i).SetCellValue(parms_header[keys[i]]);
- }
- int rowIndex = ;
- foreach (var item in list)
- {
- IRow rowTmp = sheet.CreateRow(rowIndex);
- for (int i = ; i < keys.Count; i++)
- {
- string cellValue = "";
- object properotyValue = null;
- System.Reflection.PropertyInfo properotyInfo = null;
- if (keys[i].IndexOf(".") >= )
- {
- string[] properotyArray = keys[i].Split(new string[] { "." }, StringSplitOptions.RemoveEmptyEntries);
- string subClassName = properotyArray[];
- string subClassProperotyName = properotyArray[];
- System.Reflection.PropertyInfo subClassInfo = item.GetType().GetProperty(subClassName);
- if (subClassInfo != null)
- {
- var subClassEn = item.GetType().GetProperty(subClassName).GetValue(item, null);
- properotyInfo = subClassInfo.PropertyType.GetProperty(subClassProperotyName);
- if (properotyInfo != null)
- {
- properotyValue = properotyInfo.GetValue(subClassEn, null);
- }
- }
- }
- else
- {
- properotyInfo = item.GetType().GetProperty(keys[i]);
- if (properotyInfo != null)
- {
- properotyValue = properotyInfo.GetValue(item, null);
- }
- }
- if (properotyValue != null)
- {
- cellValue = properotyValue.ToString();
- if (cellValue.Trim() == "0001/1/1 0:00:00" || cellValue.Trim() == "0001/1/1 23:59:59")
- {
- cellValue = string.Empty;
- }
- }
- rowTmp.CreateCell(i).SetCellValue(cellValue);
- }
- rowIndex++;
- }
- for (int i = ; i <= parms_header.Count(); i++)
- {
- sheet.AutoSizeColumn(i);
- }
- for (int columnNum = ; columnNum <= parms_header.Count(); columnNum++)
- {
- int columnWidth = sheet.GetColumnWidth(columnNum) / ;
- for (int rowNum = ; rowNum <= sheet.LastRowNum; rowNum++)
- {
- IRow currentRow;
- if (sheet.GetRow(rowNum) == null)
- {
- currentRow = sheet.CreateRow(rowNum);
- }
- else
- {
- currentRow = sheet.GetRow(rowNum);
- }
- if (currentRow.GetCell(columnNum) != null)
- {
- ICell currentCell = currentRow.GetCell(columnNum);
- int length = Encoding.Default.GetBytes(currentCell.ToString()).Length;
- if (columnWidth < length)
- {
- columnWidth = length;
- }
- }
- }
- sheet.SetColumnWidth(columnNum, columnWidth * );
- }
- return workbook;
- }
- catch (Exception ex)
- {
- throw ex;
- }
- }
- }
- jQuery.download = function (data) {
- var inputs = '';
- Object.keys(data).forEach(function (v) {
- inputs = inputs + '<input type="hidden" name="' + v + '" value="' + data[v] + '" />';
- })
- jQuery('<form action="/xykj/system/" method="post">' + inputs + '</form>')
- .appendTo('body').submit().remove();
- };
- function Export() {
- var parm = {
- export: 1,
- }
- $.each($("#search").serializeArray(), function () {
- if (parm[this.name]) {
- if (!parm[this.name].push) {
- parm[this.name] = [parm[this.name]];
- }
- parm[this.name].push(this.value || '');
- } else {
- parm[this.name] = this.value || '';
- }
- })
- $.download(parm);
- }
使用Ajax提交会导致 Response.Flush();无效
c# NPOI aspx导出数据的更多相关文章
- 使用npoi.dll导出数据到excel
.net数据导出excel数据有多种方法,最常用的就是使用office组件,但随之而来的问题也很棘手,又要调权限又要确定是否安装office很是麻烦,最近一个项目中也有数据导出功能,随使用excel模 ...
- asp.net使用MVC4框架基于NPOI做导出数据到Excel表
NPOI 是 POI 项目的 .NET 版本.POI是一个开源的Java读写Excel.WORD等微软OLE2组件文档的项目. 使用 NPOI 你就可以在没有安装 Office 或者相应环境的机器上对 ...
- NPOI 通用导出数据到Excel 分类: C# Helper 2014-11-04 16:06 246人阅读 评论(0) 收藏
应用场景: 在项目中,经常遇到将数据库数据导出到Excel,针对这种情况做了个程序封装.工作原理:利用NPOI将SQL语句查询出的DataTable数据导出到Excel,所见即所得. 程序界面: ...
- NPOI导出数据到Excel
NPOI导出数据到Excel 前言 Asp.net操作Excel已经是老生长谈的事情了,可下面我说的这个NPOI操作Excel,应该是最好的方案了,没有之一,使用NPOI能够帮助开发者在没有安装微 ...
- 使用NPOI导入导出Excel(xls/xlsx)数据到DataTable中
using System; using System.Collections.Generic; using System.Text; using System.IO; using NPOI.SS.Us ...
- 利用NPOI导出数据到Execl
相信很多童鞋都开发过Execl的导入导出功能,最近产品中无论是后台数据分析的需要,还是前端满足用户管理的方便,都有Execl导入导出的维护需求产生. 以前做这个功能,如果是web,利用HttpCont ...
- NPOI读取excel文件导出数据, 而此时文件正在打开中抛异常怎么办
项目中需要用到一些数值表格, 方便起见都是用excel来的. 而如果excel正打开中, 直接使用npoi制作的工具来导出数据的话, 在这一行将会异常: workbook = new XSSFWork ...
- winfrom 使用NPOI导入导出Excel(xls/xlsx)数据到DataTable中
1.通过NUGET管理器下载nopi,在引入命令空间 using System; using System.Collections.Generic; using System.Text; using ...
- NET使用NPOI组件将数据导出Excel-通用方法 【推荐】
一.Excel导入及导出问题产生: 从接触.net到现在一直在维护一个DataTable导出到Excel的类,时不时还会维护一个导入类.以下是时不时就会出现的问题: 导出问题: 如果是as ...
随机推荐
- LuoguP2698 【[USACO12MAR]花盆Flowerpot】
题目描述 首先我们简化一下题意: 要找一段区间[L,R],使区间[L,R]内元素最大值减最小值大于等于D. 做法: 首先很容易想到采用二分,分什么呢? 我们二分区间长度为mid 这个时候,检验就成为了 ...
- Delphi RSA加解密【 (RSA公钥加密,私钥解密)、(RSA私钥加密,公钥解密)、MD5加密、SHA加密】
作者QQ:(648437169) 点击下载➨delphi RSA加解密 [Delphi RSA加解密]支持 (RSA公钥加密,私钥解密).(RSA私钥加密,公钥解密).MD5加密.SHA1加密.SHA ...
- 简单的爬虫程序以及使用PYQT进行界面设计(包含源码解析)
由于这个是毕业设计的内容,而且还是跨专业的.爬虫程序肯定是很简单的,就是调用Yahoo的API进行爬取图片.这篇博客主要讲的是基础的界面设计. 放上源码,然后分部解析一下重要的地方.注:flickra ...
- STM32 EV1527无线通信(433)
EV1527无线通信 先说一下这个通信协议的数据格式,这个图片是我在手册里截的. 大家按照单片机类型计算周期,我的是STM32f103vb (4CLK大致等于350um) 发送时按照 先发同步码后发D ...
- Go MongoDB官方数据库驱动之增删改查
package main import ( "context" "fmt" "log" "go.mongodb.org/mongo ...
- Go基础编程实践(七)—— 并发
同时运行多个函数 观察常规代码和并发代码的输出顺序. // 常规代码,顺序执行,依次输出 package main import ( "fmt" "time" ...
- vue SPA设计 history hash
<body> <h3>Histort api</h3> <a class="api a">a,html</a> < ...
- P1018 乘积最大(DP)
题目 P1018 乘积最大 解析 区间DP 设\(f[i][j]\)表示选\(i\)个数,插入\(j\)个乘号时的最大值 设\(num[i][j]\)是\(s[i,j]\)里的数字 转移方程就是\(f ...
- python二维数组切片
python中list切片的使用非常简洁.但是list不支持二维数组.仔细研究了一下发现,因为list不是像nampy数组那么规范.list非常灵活.所以没办法进行切片操作. 后来想了两个办法来解决: ...
- Swiper4的基本使用
基本介绍: 中文文档地址:https://www.swiper.com.cn/ 它是一个开源,免费,强大的触摸滑动插件. 它是用纯Javascript打造的滑动特效插件,既可用于PC端,也可用于移动端 ...